参数化sql ,总提示有语法错误

原sql="selecttop"+top.Text+"totalfromtable1"运行正常,后用参数化sql的形式:sql="selecttop@top1totalf... 原sql="select top "+top.Text+" total from table1" 运行正常,后用参数化sql的形式:
sql="select top @top1 total from table1 " ;
SqlCommand cmd = new SqlCommand();
cmd.Connection = con;
cmd.Parameters.Add("@top1", SqlDbType.NVarChar, 50);
cmd.Parameters["@top1"].Value = top.Text;
cmd.CommandText = sql; ……
但运行总出现“@top1附近有语法错误”,我尝试把类型改为INT但仍然出错。请各位帮我看一下。
展开
 我来答
路人生
2011-01-07 · 超过12用户采纳过TA的回答
知道答主
回答量:66
采纳率:0%
帮助的人:23.5万
展开全部
应该可以用两种解决方式:
一、尝试,sql="select top convert(@top1,int,NVarChar) total from table1 "
二、可以用存储过程来解决,传递参数进去,组合sql执行

参考资料: http://www.bd160.com/pc/

本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
js521chx
2011-01-06 · 超过15用户采纳过TA的回答
知道答主
回答量:76
采纳率:0%
帮助的人:49.4万
展开全部
top 后面不能用@参数的形式带入值,只能用"top "+top.text+"...这种形式添加参数
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ddruk
2011-01-06 · 超过18用户采纳过TA的回答
知道答主
回答量:72
采纳率:0%
帮助的人:45.9万
展开全部
这个TOP 后面不能接变量的.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
长朦
2011-01-06 · TA获得超过249个赞
知道小有建树答主
回答量:500
采纳率:0%
帮助的人:243万
展开全部
应该是INT类型
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式