排序order by后面以用 @ 吗,是不是必须要指定列名

wzy528 2010-10-20 08:03:09
string sql = "SELECT * FROM books Order By @order";

SqlDataReader dr = DBHelper.GetReader(sql, new SqlParameter("@order", order));





我这么写他就报错


由 ORDER BY 编号 1 标识的 SELECT 项包含一个变量,作为标识列位置的表达式的一部分。按照引用列名的表达式排序时,只允许使用变量。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。

异常详细信息: System.Data.SqlClient.SqlException: 由 ORDER BY 编号 1 标识的 SELECT 项包含一个变量,作为标识列位置的表达式的一部分。按照引用列名的表达式排序时,只允许使用变量。


----------------------------------------------------------------------------------------------------



我要是这么写他就可以运行


string sql = "SELECT * FROM books Order By " + order;

SqlDataReader dr = DBHelper.GetReader(sql);





...全文
269 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
hao1hao2hao3 2010-10-20
  • 打赏
  • 举报
回复
[Quote=引用楼主 wzy528 的回复:]
string sql = "SELECT * FROM books Order By @order";

SqlDataReader dr = DBHelper.GetReader(sql, new SqlParameter("@order", order));
[/Quote]

你这样写就要通过动态SQL语句来实现了,写法不同,
wuyq11 2010-10-20
  • 打赏
  • 举报
回复
top n和列名不能作为参数
sql2008开始支持
set @sql=@sql +' Order By '+@order
exec(@sql)
kkbac 2010-10-20
  • 打赏
  • 举报
回复
order by 后面不能加参数吧。

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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