因为一个小程序,第一次知道SQL还有CASE WHEN这种代码。
举个例子,就是有个表,有班级,学号,分数。
我想弄个统计,选出的表是:班级,60分以上学生个数,60分以下学生个数,如何在使用一句SQL表达?
如果是统计只统计班级单种类型学生个数,代码很简单:
select 班级,count(*) from 表 where 分数>=60 group by班级;
select 班级,count(*) from 表 where 分数<60 group by班级;
当然使用join也可以弄,这里使用CASE WHEN代码仅用一句SQL:
select 班级,count(case when 分数>=60 then 分数 else nullend),count(case when 分数<60 then 分数 else null end)from 表 group by 班级;
这是问题来了,明明在MYSQL中能够正常得出结果,但是弄到HQL就不行了,会出错!
后面找了半天终于找到一个解决方法:
HQL:
举个例子,就是有个表,有班级,学号,分数。
我想弄个统计,选出的表是:班级,60分以上学生个数,60分以下学生个数,如何在使用一句SQL表达?
如果是统计只统计班级单种类型学生个数,代码很简单:
select 班级,count(*) from 表 where 分数>=60 group by班级;
select 班级,count(*) from 表 where 分数<60 group by班级;
当然使用join也可以弄,这里使用CASE WHEN代码仅用一句SQL:
select 班级,count(case when 分数>=60 then 分数 else nullend),count(case when 分数<60 then 分数 else null end)from 表 group by 班级;
这是问题来了,明明在MYSQL中能够正常得出结果,但是弄到HQL就不行了,会出错!
后面找了半天终于找到一个解决方法:
HQL:
select 班级,sum(case when 分数>=60 then 1 else 0end),sum(case when 分数<60 then 1 else 0 end) from 表group by 班级;
转载于:http://hi.baidu.com/mark_l/item/8773badc8e94964dddf9bee4
本文介绍了如何使用 SQL 的 CASE WHEN 语句来统计不同分数段的学生数量,并对比了 MySQL 和 HQL 中的不同实现方式。
3075

被折叠的 条评论
为什么被折叠?



