【Listing 3:用列名字作为参数,第二次尝试】
ALTER PROC GetSortedShippers
@ColName AS sysname
AS
SELECT *
FROM Shippers
ORDER BY
CASE @ColName
WHEN @#ShipperID@#
THEN CAST(ShipperID AS varchar(11))
WHEN @#CompanyName@#
THEN CompanyName
WHEN @#Phone@#
THEN Phone
ELSE NULL
END
现在,假设我们再把三个列名字中的任意一个作为参数调用存储过程,输出结果看起来正确。看起来就象指定的列正确地为查询输出提供了排序标准。但这个表只有三个货主,它们的ID分别是1、2、3。
延伸阅读
文章来源于领测软件测试网 https://www.ltesting.net/