数据库sql中的case语句~

数据库sql中的case语句~,第1张

SQL语句中的CASE语句与高级语言中的switch语句,是标准SQL的语法,适用与一个条件判断有多种值的情况下分别执行不同的 *** 作

灵活应用CASE语句可以使SQL语句变得简洁易读.

Case 使用方法:

Case具有两种格式。简单Case函数

和Case搜索函数。 --简单Case

函数

CASE sex

WHEN '1' THEN '男'

WHEN '2' THEN '女'

ELSE '其他' END

--Case搜索函数

CASE WHEN sex = '1' THEN '男'

WHEN sex = '2' THEN '女'

ELSE '其他' END

这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。

还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。

--比如说,下面这段SQL,你永远无法得到“第二类”这个结果

CASE WHEN col_1 IN ( 'a', 'b') THEN '第一类'

WHEN col_1 IN ('a')       THEN '第二类'

ELSE'其他' END

SELECT

'Price

Category'

=

CASE

WHEN

price

IS

NULL

THEN

'Not

yet

priced'

WHEN

price

<

10

THEN

'Very

Reasonable

Title'

WHEN

price

>=

10

and

price

<

20

THEN

'Coffee

Table

Title'

ELSE

'Expensive

book!'

END

先说下,case要和end一块用。

从上面可以看出,case里用的是when

then

形式,从整个case

end来看,它是从自己的多个语句中择一输出结果。

如果是把when

看成if

,就好理解多了,if语句就像是筛子里的石子,而case

end就是筛子,只会允许一个符合它网眼大小的石头出去,并且会将这个石子打包成一个可用的表达式。

case when...then...else...end是sql查询的过滤条件,在做统计的时候常常使用。

表order(id, status)

select count(*) 订单数,sum(case when a.status='1' then 1 else 0 end) 待付款,sum(case when a.status='2' then 1 else 0 end) 待发货,sum(case when a.status='3' then 1 else 0 end) 待收货,sum(case when a.status='4' then 1 else 0 end) 已完成,sum(case when a.status='5' then 1 else 0 end) 已取消 from order

Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9910056.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存