zoukankan      html  css  js  c++  java
  • 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)
  • 相关阅读:
    pycharm+Locust搭建性能测试框架和执行环境
    mapbox构建3D建筑展示
    搭建自动化测试平台 (selenium+testng+maven+svn+Jenkins)
    chromedriver与chrome各版本及下载地址
    python的位置参数、默认参数、关键字参数、可变参数区别
    ArcMap10.5几何网络分析术语
    CSS 水平居中
    行内元素的padding和margin是否有效
    一个未知宽高的元素在div中垂直水平居中
    CSS 3-浮动、定位
  • 原文地址:https://www.cnblogs.com/coder-lzh/p/8819140.html
Copyright © 2011-2022 走看看