带参数sql语句怎么不能在程序中把参数带进去?

Renzhe 2003-10-12 01:07:32
OleDbCommand qbComm=conn.CreateCommand();
qbComm.CommandText = "select jbcc from qb_sjr_bt where to_char(rksj,'yyyymmdd') = '@rksj'";
qbComm.Parameters.Add("@rksj",OleDbType.Char,8);
qbComm.Parameters["@rksj"].Value = "@rksj";
OleDbDataReader qbReader = qbComm.ExecuteReader();
while(qbReader.Read())
{
listBox1.Items.Add(qbReader["jbcc"]);
}
程序片断如上,后台用的是oracle9i,如果把sql语句的参数换成固定的数值,则可以返回结果,但如果把@rksj用别的方法取得,则不能返回任何结果,也不报错!
请哪位大虾指点一下!
...全文
94 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
Renzhe 2003-10-12
  • 打赏
  • 举报
回复
谢谢!我已经试验成功了!
vs.net 2003已经加入了对oracle的支持,有了OracleClient,OracleCommand,OracleDataAdapter等类;
在oracle中使用参数应该用:(冒号),而不是@.
再次对 cnming(cnming)表示感谢!
cnming 2003-10-12
  • 打赏
  • 举报
回复
OleDbCommand qbComm=conn.CreateCommand();
qbComm.CommandText = "select jbcc from qb_sjr_bt where to_char(rksj,'yyyymmdd') = ?";
qbComm..Parameters.Add("@rksj", this.textBox1.text);

OleDbDataReader qbReader = qbComm.ExecuteReader();
while(qbReader.Read())
{
listBox1.Items.Add(qbReader["jbcc"]);
}


试试看这个,我在精简版中用过,这里参数按照“?”的次序和个数输入参数
Renzhe 2003-10-12
  • 打赏
  • 举报
回复
up
Renzhe 2003-10-12
  • 打赏
  • 举报
回复
不好意思,
下面这句写错了
qbComm.Parameters["@rksj"].Value = "@rksj";
应该是
qbComm.Parameters["@rksj"].Value = textBox1.text;

110,533

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧