参数化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但仍然出错。请各位帮我看一下。 展开
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但仍然出错。请各位帮我看一下。 展开
4个回答
展开全部
应该可以用两种解决方式:
一、尝试,sql="select top convert(@top1,int,NVarChar) total from table1 "
二、可以用存储过程来解决,传递参数进去,组合sql执行
一、尝试,sql="select top convert(@top1,int,NVarChar) total from table1 "
二、可以用存储过程来解决,传递参数进去,组合sql执行
参考资料: http://www.bd160.com/pc/
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
top 后面不能用@参数的形式带入值,只能用"top "+top.text+"...这种形式添加参数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个TOP 后面不能接变量的.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
应该是INT类型
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询