数据库查询结果的动态排序(6)

浪子冰雕

浪子冰雕

2016-01-29 16:19

数据库查询结果的动态排序(6),数据库查询结果的动态排序(6)
    现在,如果我们用任意三个列名字之一作为参数调用存储过程,存储过程都能够正确地返回结果。Richard Romley提出了一种巧妙的处理方法,如Listing 6所示。它不再要求我们搞清楚可能涉及的列数据类型。这种方法把ORDER BY子句分成三个独立的CASE表达式,每一个表达式处理一个不同的列,避免了由于CASE只返回一种特定数据类型的能力而导致的问题。



【Listing 6:用列名字作为参数,Romley提出的方法】


ALTER PROC GetSortedShippers

@ColName AS sysname

AS


SELECT *

FROM Shippers

ORDER BY

CASE @ColName WHEN 'ShipperID'

THEN ShipperID ELSE NULL END,

CASE @ColName WHEN 'CompanyName'

THEN CompanyName ELSE NULL END,

CASE @ColName WHEN 'Phone'

THEN Phone ELSE NULL END





  按照这种方法编写代码,SQL Server能够为每一个CASE表达式返回恰当的数据类型,而且无需进行数据类型转换。但应该注意的是,只有当指定的列不需要进行计算时,索引才能够优化排序操作。

 
展开更多 50%)
分享

猜你喜欢

数据库查询结果的动态排序(6)

SQLServer
数据库查询结果的动态排序(6)

数据库查询结果的动态排序(2)

SQLServer
数据库查询结果的动态排序(2)

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

数据库查询结果的动态排序(4)

SQLServer
数据库查询结果的动态排序(4)

数据库查询结果的动态排序(1)

SQLServer
数据库查询结果的动态排序(1)

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

数据库查询结果的动态排序(5)

SQLServer
数据库查询结果的动态排序(5)

数据库查询结果的动态排序(7)

SQLServer
数据库查询结果的动态排序(7)

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

Photoshop教程:制作照片卷边立体效果

Photoshop教程:制作照片卷边立体效果

无线连接疯狂断线原因分析

无线连接疯狂断线原因分析
下拉加载更多内容 ↓