OleDBConnection连接SQL Server表时,OleDbCommand在使用Update语句时,使用参数出错

本文探讨了在使用System.Data.OleDb进行数据库操作时遇到的@name变量未声明错误,并提供了具体的代码实例。文章指出,通过使用System.Data.SqlClient可以避免此类问题,推测这可能是由于SqlOleDb驱动本身的限制导致。
 
System.Data.OleDb.OleDBConnection OleDbCNN;
System.Data.OleDb.OleDbCommand OleDbCMD;
string cs;
cs = "Provider=sqloledb;Data Source=XMH//mySQL;Initial Catalog=DataSql;Integrated Security=SSPI;"
OleDbCNN = new System.Data.OleDb.OleDBConnection(CNNStr);
cs = "UPDATE TabSql set XM=@name, XB=@sex where zkzh=0640240101"
OleDbCMD = new System.Data.OleDb.OleDbCommand();
OleDbCMD.CommandType = CommandType.Text;
OleDbCMD.Connection = OleDbCNN;
OleDbCMD.CommandText = cs;
OleDbCMD.Parameters.Add("@name", OleDbType.VarChar);
OleDbCMD.Parameters["@name"].Value = "张山";
OleDbCMD.Parameters.Add("@name", OleDbType. VarChar);
OleDbCMD.Parameters["@sex"].Value = "男";
OleDbCNN.Open();
OleDbCMD.ExecuteNonQuery();
       运行时出现“@name变量未声明”错误。使用System.Data.SqlClient.SqlConnectionSqlCommand、SqlDataReader时则不存在此问题。
估计是SqlOleDb驱动的问题。
 
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值