视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
.net用OLEDB方式操作SqlServer和Sybase
2020-11-09 07:45:50 责编:小采
文档


【错误一】 SqlServer提示错误:OleDbException 必须声明标量变量 今天用.net使用Oledb的方式操作SqlServer,却总是莫名其妙的报“必须声明标量变量…”,在代码里面分别采用了下面的两种方式,都无济于事: 方法一: OleDbParameter [] p = new OleDbParamete

【错误一】 SqlServer提示错误:OleDbException 必须声明标量变量

今天用.net使用Oledb的方式操作SqlServer,却总是莫名其妙的报“必须声明标量变量…”,在代码里面分别采用了下面的两种方式,都无济于事:

方法一:
OleDbParameter[] p = new OleDbParameter[] { new OleDbParameter("@aa",1), new OleDbParameter("@bb","shelley"), new OleDbParameter("@cc",DateTime.Now)};Objcmd.Parameters.AddRange(p);方法二:
OleDbParameter pp;pp = new OleDbParameter("@aa",OleDbType.Integer);pp.Value = 1;Objcmd.Parameters.Add(pp);pp = new OleDbParameter("@bb", OleDbType.LongVarChar);pp.Value = "shelley";Objcmd.Parameters.Add(pp);pp = new OleDbParameter("@cc", OleDbType.Date);pp.Value = DateTime.Now;Objcmd.Parameters.Add(pp);
无论怎么样写,都会提示“必须声明标量变量@aa”,最终的原因是下面这句:
OleDbCommand Objcmd = new OleDbCommand("insert into test (a,b,c)values(@aa,@bb,@cc)", Objconn);
正确写法:
OleDbCommand Objcmd = new OleDbCommand("insert into test (a,b,c)values(?,?,?)", Objconn);
这样就正常通过了。
 
【错误二】Sybase提示错误:不支持此接口 (异常来自 HRESULT:0x80004002 (E_NOINTERFACE))

.net用Oledb操作Sybase,因为在一个sql语句中可能会多次用到同一个参数,代码如下:

OleDbCommand Objcmd = new OleDbCommand("update test set a=@aa where a=@aa", Objconn);OleDbParameter[] p = new OleDbParameter[] { new OleDbParameter("aa",1), new OleDbParameter("aa",1)};Objcmd.Parameters.AddRange(p);Objconn.Open();Objcmd.ExecuteNonQuery();Objconn.Close();

上面的代码就会提示“不支持此接口 (异常来自 HRESULT:0x80004002 (E_NOINTERFACE))”错误。问题原因在于参数中存在两个相同名字,对于这种情况只需要写一个参数就可以了,改动如下:

OleDbCommand Objcmd = new OleDbCommand("update test set a=@aa where a=@aa", Objconn);OleDbParameter[] p = new OleDbParameter[] { new OleDbParameter("aa",1)};

OleDbCommand Objcmd = new OleDbCommand("update test set a=@aa where a=@aa2", Objconn);OleDbParameter[] p = new OleDbParameter[] { new OleDbParameter("aa",1), new OleDbParameter("aa2",1)};

【总结】

如果写一个程序,需要支持SqlServer和Sybase的时候这个地方需要特别注意:

1.SqlServer需要用“?”作为参数占位符,这样要求即使用到了同一个参数,也必须多次添加Parameter;

2.Sybase如果多次使用同一个参数,不能多次添加Parameter,否则会报错;

下载本文
显示全文
专题