SQL Server:查询时将空字段排在下面的方法

来源:未知 责任编辑:责任编辑 发表时间:2013-08-27 11:17 点击:

如果需要将查询结果里面的空字段排序到下面,可以采用下面的两种方法:

 

方法一:

 

 

<span style="font-size:16px;">SELECT AA,BB,CC FROM Table ORDER BY ISNULL(AA,'ZZZZ'),ISNULL(BB,'ZZZZ'),CC</span> 

解释:这种方法是在排序的时候,判断字段是否为空,当为空的时候,就将单引号中的内容作为字段内容来参加排序。这时候,只需要在单引号中写一个肯定是列的最大值的内容就可以了。

 

 

方法二:

 

 

<span style="font-size:16px;">SELECT AA,BB,CC FROM TABLE ORDER BY 

    (CASE WHEN AA IS NULL THEN 1 ELSE 0 END),AA, 

    (CASE WHEN BB IS NULL THEN 1 ELSE 0 END),BB</span> 

 

也可以写成:

 

SELECT AA,BB,CC FROM TABLE ORDER BY 

    (CASE WHEN AA IS NULL THEN 1 ELSE 0 END), 

    (CASE WHEN BB IS NULL THEN 1 ELSE 0 END), 

    AA,BB   

 

作者  云海深处

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • sql常见面试题
    • SQL SERVER 2005性能之跟踪
    • SQL编程(一)
    • LINUX上RMAN自动备份脚本
    • sql server面试题
    • 如何将多个SQL查询统计结果一次显示出来
    • 浅谈SQL Server中的事务日志(三)----在简单恢复模式下日志的角色
    • sql server 列转行
    • SQL小技巧系列 --- 行转列合并
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1