sql server select case when的用法

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

sql server select case when的用法

select case when

CASE WHEN condition THEN result[WHEN ...][ELSE result]END

CASE 子句可以用于任何表达式可以有效存在的地方。 condition 是一个返回boolean 的表达式。如果结果为真,那么 CASE 表达式的结果就是符合条件的 result。如果结果为假,那么以相同方式搜寻任何随后的 WHEN 子句。如果没有 WHEN condition 为真,那么case 表达式的结果就是在 ELSE 子句里的值。如果省略了 ELSE 子句而且没有匹配的条件,结果为 NULL。

例子:

SELECT * FROM test; a---123 SELECT a, CASE WHEN a=1 THEN 'one' WHEN a=2 THEN 'two'ELSE 'other'ENDFROM test; a | case---+-------1 | one2 | two3 | other

所有 result 表达式的数据的类型都必须可以转换成单一的输出类型。

下面这个"简单的" CASE 表达式是上面的通用形式的一个特殊的变种。

CASE expression WHEN value THEN result[WHEN ...][ELSE result]END

先计算 expression 的值,然后与所有在WHEN 子句里声明的 value 对比,直到找到一个相等的。如果没有找到匹配的,则返回在 ELSE 子句里的 result (或者 NULL)。这个类似于 C 里的 switch 语句。

上面的例子可以用简单 CASE 语法来写:

SELECT a, CASE a WHEN 1 THEN 'one' WHEN 2 THEN 'two'ELSE 'other'ENDFROM test; a | case---+-------1 | one2 | two3 | other

CASE 表达式并不计算任何对于判断结果并不需要的子表达式。比如,下面是一个可以避免被零除的方法:

CASE WHEN (u.mamount01 != 0) THEN 100.00*u.mamount03/u.mamount01 ELSE 0.00 END AS mamountlv。

将结果保留2位小数:

CASE WHEN u.mamount01 != 0 THEN cast(100.00*u.mamount03/u.mamount01 as dec(10,2)) ELSE 0.00 END AS mamountlv

相关文档
最新文档