mysql数据库中case when 的用法
oracle 的case when 语法需要注意下。end不需要写双引号
case when to_char(a.STARTING_TIME,\'d\')=5 then \'周四\' ELSE \'其他\' END 来源,
场景1:比如说我们在数据库存了性别的字段,一般都是存0 和 1 代表男和女 然后我们会得到0和1之后在java中判断 ,很麻烦有么有?其实我们完全可以在sql中判断好之后拿来现成的。就是在sql中做判断就ok
SELECT *, CASE WHEN ly = \'app\' then \'手机\' WHEN ly = \'pc\' then \'电脑\' ELSE \'其他\' END \'来源\' FROM stu
结果:
1 张1 1 pc 电脑
2 张2 1 app 手机
3 张3 1 app 手机
4 张4 2 app 手机
很简单 ,就是做个判断 固定语法 这是最简单的用法 看一眼就知道什么意思
场景2:比如说一个学生表,有学生id,名字,老师id,来源(app或者pc) 我们有这样的一个需求 我们想知道每个老师有几个学生,并且这些学生里面 来自app的有几个 来自pc的有几个。
这个就有点麻烦了,要看每个老师下面有几个学生 肯定是将老师id分组 然后count(1) , 这个简单 但是 我们还要知道每个老师下面学生分别来自app几个 pc端几个 无疑还是要用到count 然后再搭配case when 的用法来判断 好了 看代码
SELECT count(1) \'数量\', stu.tid, COUNT(CASE WHEN ly = \'pc\' then 1 END) pc, COUNT(CASE WHEN ly = \'app\' then 1 END) app FROM stu GROUP BY tid //结果
总数 老师id pc app 3 1 1 2 1 2 0 1
意思就是说 只要ly=pc 就算符合一条 然后用count累加 后面的那个1 无关紧要,你写任意数字都可以 但是我们习惯上都写1 比如我们习惯上统计总数喜欢count(1)