首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

case when then else end 应用学习

2012-07-04 
case when then else end 使用学习国家(country)人口(population)中国600美国100加拿大100英国200法国300

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 )

女职员的条件倒是符合了,男职员就无法输入了。

?

?

?

热点排行