排序order by后面以用 @ 吗,是不是必须要指定列名
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);