首页 > 数据库 > mysql教程 > select中case when的使用_MySQL

select中case when的使用_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-01 13:29:20
原创
1586 人浏览过

bitsCN.com

select中case when的使用

 

select 与 case结合使用最大的好处有两点,一是在显示查询结果时可以灵活的组织格式,二是有效避免了多次对同一个表或几个表的访问。

例1:表 students(id, name ,birthday, sex, grade),要求按每个年级统计男生和女生的数量各是多少,统计结果的表头为,年级,男生数量,女生数量。如果不用select case when,为了将男女数量并列显示,统计起来非常麻烦,先确定年级信息,再根据年级取男生数和女生数,而且很容易出错。用select case when写法如下:

SELECT   grade, COUNT (CASE WHEN sex = 1 THEN 1      /*sex 1为男生,2位女生*/                                            ELSE NULL                                            END) 男生数,                            COUNT (CASE WHEN sex = 2 THEN 1                                            ELSE NULL                                            END) 女生数    FROM students GROUP BY grade
登录后复制

例2:

pat_visit.admission_date_time的日期格式为YYYY-MM-DD HH24:MI,求患者的年龄。create orreplaceview yw_viewas( selectcasewhen trunc(a.admission_date_time-b.date_of_birth)<30 and floor(a.admission_date_time-b.date_of_birth)>=1 then  round(a.admission_date_time-b.date_of_birth)||&#39;天&#39;  whenround(a.admission_date_time-b.date_of_birth)>30 andround(a.admission_date_time-b.date_of_birth)<365 then  round((a.admission_date_time-b.date_of_birth)/30)||&#39;月&#39; whenfloor(a.admission_date_time-b.date_of_birth)>&#39;365&#39;then  round((a.admission_date_time-b.date_of_birth)/365)||&#39;岁&#39;  whenceil(a.admission_date_time-b.date_of_birth)<=&#39;1&#39;then  round((a.admission_date_time-b.date_of_birth)*24*60)||&#39;分钟&#39;  end  as年龄,a.patient_idfrom pat_visit a,pat_master_index bwhere a.patient_id=b.patient_id);
登录后复制

 


bitsCN.com
相关标签:
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
php 计算数组最大最小值 大神进
来自于 1970-01-01 08:00:00
0
0
0
objective-c - 如何在栈区获取最大值最小值?
来自于 1970-01-01 08:00:00
0
0
0
javascript - 原生js求DOM树的最大深度
来自于 1970-01-01 08:00:00
0
0
0
寻大牛二开一下系统 预算好说 语言最好PH
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板