C#.net ,报错 “必须声明标量变量 "@taskNum"“,为什么?

this.taskNum=this.dgvUnfinishedTask.CurrentRow.Cells[3].ToString();sql=@"select任务明细fr... this.taskNum = this.dgvUnfinishedTask.CurrentRow.Cells[3].ToString();
sql = @"select 任务明细 from TaskDetail where 任务编号 = @taskNum";
SqlConnection conn = new SqlConnection(conString);
SqlCommand cmd = new SqlCommand(sql, conn);
SqlDataAdapter da = new SqlDataAdapter(sql, conn);
D1 = new DataTable();
cmd.Parameters.Add("@taskNum", SqlDbType.VarChar, 50);

conn.Open();
cmd.Parameters["@taskNum"].Value = this.taskNum;
da.Fill(D1);
this.rtbTaskDetail.Text= D1.Rows[0][0].ToString();
conn.Close();
D1.Dispose();
展开
 我来答
victor797
2012-05-05
知道答主
回答量:28
采纳率:0%
帮助的人:7.4万
展开全部
调试一下先,看在哪一行出错。
还有就是我不知道你这个顺序对不对,我觉得不合适。
比如正确的顺序是先Open连接,然后再做其它的操作,因为你的cmd里面在打开连接前,是什么都不存在的,包括你的"@taskNum"。只有打开了连接才存在,还有就是,既然有了参数了,就不要用this.rtbTaskDetail.Text= D1.Rows[0][0].ToString();。
太土了你不觉得吗。

你肯定是抄人家的例子,但是没理解,所以把Open连接放到了后面。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
蔡德江
2012-05-05 · TA获得超过3187个赞
知道大有可为答主
回答量:1700
采纳率:0%
帮助的人:1441万
展开全部
command.Parameters.Add("@ID", SqlDbType.Int);
command.Parameters["@ID"].Value = customerID;
要这种形式的customerID 是你对应的条件的值
比如是查询的条件来自一个文本框 这个值就是文本框的值
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
huangpeng0419
2012-05-05 · TA获得超过357个赞
知道小有建树答主
回答量:569
采纳率:100%
帮助的人:301万
展开全部
cmd这个对象没有用到。
SqlDataAdapter da = new SqlDataAdapter(cmd);
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友38b75e5
2012-05-05 · TA获得超过103个赞
知道小有建树答主
回答量:281
采纳率:0%
帮助的人:203万
展开全部
sql语句中不能这么写
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式