T-SQL 基于列的逻辑表达式 (CASE)
CASE简介
基于列的逻辑表达式,其实就是CASE表达式.可以用在SELECT,UPDATE,DELETE,SET以及IN,WHERE,ORDER BY和HAVING子句之后。由于这里讲的是T-SQL查询,所以只说到CASE表达式在SELECT子句和ORDER BY子句中的使用。
CASE表达式的作用与编程语言中的IF…THEN…ELSE逻辑类似。只是CASE表达式在T-SQL中并不能控制T-SQL程序的流程,只是作为基于列的逻辑使用。
一个简单的示例,假设有这样一张表:
在查询的时候,对于列Sex,如果是False就显示男,如果是True就显示女。
语句如下:

SELECT Id,Name,
CASE Sex
WHEN 0 THEN '男'
WHEN 1 THEN '女'
ELSE '不清楚'
END AS 性别
FROM PERSON

显示结果如下:
CASE表达式实际情况可以分为两种:
- CASE简单表达式(CASE Simple Expression):将某个表达式与一组简单表达式进行比较以确定结果。
- CASE 搜索表达式(CASE Searched Expression):计算一组布尔表达式以确定结果。
下面分别介绍这两种方式。
CASE简单表达式
在CASE简单表达式中,整个表达式只会取一列的值做相应的判断。就如同上面的例子一样,现在只给出另外一种等价的写法。

SELECT Id,Name,
性别 = CASE Sex --区别仅仅是将别名放到这里而已
WHEN 0 THEN '男'
WHEN 1 THEN '女'
ELSE '不清楚'
END
FROM PERSON

因为CASE表达式的值只局限在一列当中,所以THEN后面的值数据类型必须相同,或者兼容,否则就会报错。
在上面语句中,还有一个可选的“ELSE”语句,这个语句可以省略,但最好的做法是保留ELSE,否则不在匹配值范围内的所有值都会为“NULL”。
CASE搜索表达式
与CASE简单表达式不同,CASE搜索表达式提供了更强大的功能,CASE搜索表达式不仅可以使用更复杂的逻辑表达式,而且还能够根据多个列的数据确定所显示列的值。
那么如何根据列来确定显示值呢,且看下面例子:

SELECT Id,Name,
性别 = CASE --注意这里的CASE后面不跟任何东西了
WHEN Sex=0 THEN '帅哥' --当然Sex你可以换成任意其他列
WHEN Sex=1 THEN '美女'
ELSE '不清楚'
END
FROM PERSON

显示结果如下:
现在来做一个根据多个列判断显示的例子,在原来的表上添加两条记录
多个列组合判断:
现在要根据Id和Sex两个列来组合判断帅哥,美女的SQL如下:

SELECT Id,Name,
CASE
WHEN Id = 3 AND Sex = 0 THEN '帅哥' --这里要注意顺序,优先显示前面匹配到的,这个后面会提到
WHEN Id = 4 And Sex = 1 THEN '美女'
WHEN Sex = 0 THEN '男'
WHEN Sex = 1 THEN '女'
ELSE '不清楚'
END AS 性别
FROM Person

显示结果如下:
范围判断:
再新建一个表如下所示:
这里要实现的效果是,当分数大于90,显示优秀,大于80,显示良好...
SQL语句如下:

SELECT Id,Name,
CASE
WHEN Score > 90 THEN '优秀'
WHEN Score > 80 THEN '良好'
WHEN Score > 70 THEN '中等'
WHEN Score > 60 THEN '及格'
ELSE '不及格'
END AS 分数
FROM Score

查询结果如下:
这里要注意WHEN…THEN是以先后顺序出现,当第一个WHEN后面的表达式为FALSE时,则会去看第二个WHEN后的表达式,依次类推。当第一个WHEN后的表达式为TRUE时,则取第一个THEN后面的值,即使第二个WHEN表达式也为TRUE。所以这里为什么刘备分数满足前面几个条件,也显示第一个结果。
CASE表达式在ORDER BY中的使用
CASE表达式在ORDER BY中可以将排序结果分类,可以使符合一定条件则升序,符合另外一定条件则降序,但总体差不多,下面给个例子。
还是刚才那张表,我想,当性别为男则Id降序排序,如果性别为女则Id升序排序。SQL语句如下:
SELECT Id,Name,Sex
FROM Person
ORDER BY
CASE WHEN Sex=0 THEN Id END DESC, --性别为男,Id降序
CASE WHEN Sex=1 THEN Id END ASC --性别为女,Id升序
显示结果如下:
T-SQL 基于列的逻辑表达式 (CASE)的更多相关文章
- T_SQL基于列的逻辑表达式(case)
本文摘自:http://www.cnblogs.com/kissdodog/p/3154371.html(感谢作者的分享,总结的很好) 基于列的逻辑表达式,其实就是CASE表达式.可以用在SELECT ...
- Sql 基于列的Case表达式
Case表达式可以用在 Select,update ,delete ,set,in,where ,order by,having子句之后, 只是case表达式不能控制sql程序的流程,只能作为基于列的 ...
- SQL Server 列存储索引强化
SQL Server 列存储索引强化 SQL Server 列存储索引强化 1. 概述 2.背景 2.1 索引存储 2.2 缓存和I/O 2.3 Batch处理方式 3 聚集索引 3.1 提高索引创建 ...
- SQL 计算列
SQL计算列,可以解决一般标量计算(数学计算,如ColumnA*ColumnB)的问题,而子查询计算(如select sum(salary) from tableOther where id=’ABC ...
- SQL Server 列存储索引概述
第一次接触ColumnStore是在2017年,数据库环境是SQL Server 2012,Microsoft开始在SQL Server 2012中推广列存储索引,到现在的SQL Server 201 ...
- 使用Spark加载数据到SQL Server列存储表
原文地址https://devblogs.microsoft.com/azure-sql/partitioning-on-spark-fast-loading-clustered-columnstor ...
- SQL 一列数据整合为一条数据
SQL 一列数据整合为一条数据: SELECT STUFF(( SELECT distinct ',' + 列名 FROM 表名 where [条件] FOR XML PATH('') ), 1 ...
- jmeter奇淫妙计之遍历sql多列结果集
foreach控制器加${__V()}函数和${__counter(TRUE,)}函数 处理sql多列结果的遍历真的是绝配啊,之前一直用循环控制器+count函数,或者while控制器加count函数 ...
- Sql 标识列 增长1000
Sql 标识列 增长1000 的解决办法: 1. Open "SQL Server Configuration Manager" 2. Click "SQL Server ...
随机推荐
- 关于PowerShell中的命令的别名
cmdlets的别名,有利于使用传统的cmd的方式 或者使用 bash的方式的人员,更加方便的使用使用频率较高的命令. 以下是从 别名中获取的内置的别名. PS C:\> Get-Alias * ...
- 关于链表的一些重要操作(Important operations on a Linked List)
上篇博文中讨论了链表的一些基本操作: 链表的基本操作(Basic Operations on a Linked List) 然而,为创建一个多功能的链表,在深度学习之前我们还需要了解更多的链表操作. ...
- 沙湖王 | 用K-均值聚类给女明星们的身材分分类
沙湖王 | 用K-均值聚类给女明星们的身材分分类 http://www.shahuwang.com/2012/07/21/%E7%94%A8scipy%E5%AE%9E%E7%8E%B0k-means ...
- Direct3D 光照和材质
今天我们来学习下Direct3D里面的光源和材质. 四大光照类型: 环境光 Ambient Light 一个物体没有被光照直接照射,通过每一些物体反射的光线到达这个物体,它也有可能被看到.这种称为 ...
- BOOST 线程完全攻略 - 基础篇
http://blog.csdn.net/iamnieo/article/details/2908621 2008-09-10 12:48 9202人阅读 评论(3) 收藏 举报 thread多线程l ...
- 常用LINUX脚本汇总(1)
1.查看磁盘使用空间 df -hl 2.查看文件或者文件夹大小 du -sh 文件(夹)名 查看文件大小 AIX系统为du -sg 3.查看当前用户下定时任务列表crontab -l 4.修改定时 ...
- [J2EE框架][Debug]
注意xml头部问题 比如在xx-servlet中注意: <mvc:annotation-driven/> <context:component-scan base-package=& ...
- J2EE项目开发流程简介
开发流程(一) 提出需求:产品部提出本周期项目的具体需求. 项目计划:项目经理协调开发部.测试部和产品部进行需求协商,产生项目计划. 需求理解:开发部和测试部向产品部提出各自对需求的理解. 产品设计: ...
- imadjust函数分析一
声明:本文涉及到的行数皆指本文提供的附件imadjust.m的代码中行数 本文只讨论imadjust函数是一种用法,即 J = IMADJUST(I,[LOW_IN; HIGH_IN],[LOW_OU ...
- Tomcat学习笔记 - 错误日志 - Tomcat访问Manager apps出现401 Unauthorized错误
原因是配置文件中未指定管理员身份. 打开tomcat>conf>tomcat-user.xml文件,添加如下代码: <role rolename="admin-gui&qu ...