case when then else end 使用学习
国家(country)人口(population)中国600美国100加拿大100英国200法国300日本250德国200墨西哥50印度250洲人口亚洲1100北美洲250其他700国家(country)性别(sex)人口(population)中国1340中国2260美国145美国255加拿大151加拿大249英国140英国260国家男女中国340260美国4555加拿大5149英国4060
普通情况下,用union也可以实现用一条语句进行查询。但是那样增加消耗(两个select部分),而且sql语句会比较长。
下面是一个是用case函数来完成这个功能的例子
select country, sum( case when sex = '1' then population else 0 end), --男性人口 sum( case when sex = '2' then population else 0 end) --女性人口 from table_a group by country;
这样我们使用select,完成对二维表的输出形式,充分显示了case函数的强大。
三,在check中使用case函数。
在check中使用case函数在很多情况下都是非常不错的解决方法。可能有很多人根本就不用check,那么我建议你在看过下面的例子之后也尝试一下在sql中使用check。
下面我们来举个例子
公司a,这个公司有个规定,女职员的工资必须高于1000块。假如用check和case来表现的话,如下所示
constraint check_salary check ( case when sex = '2' then case when salary > 1000 then 1 else 0 end else 1 end = 1 )
假如单纯使用check,如下所示
constraint check_salary check ( sex = '2' and salary > 1000 )
女职员的条件倒是符合了,男职员就无法输入了。
?
?
?