首页 >数据库 >SQL > 正文

sql中case when的用法

原创2020-02-13 16:35:0406308

sql中case when的用法

case具有两种格式。简单case函数和case搜索函数。

1、简单case函数

case sex
  when '1' then '男'
  when '2' then '女’
  else '其他' end

2、case搜索函数

case when sex = '1' then '男'
     when sex = '2' then '女'
     else '其他' end</span>

这两种方式,可以实现相同的功能。简单case函数的写法相对比较简洁,但是和case搜索函数相比,功能方面会有些限制,比如写判定式。(免费学习视频教程推荐:mysql视频教程

还有一个需要注重的问题,case函数只返回第一个符合条件的值,剩下的case部分将会被自动忽略。

比如说,下面这段sql,你永远无法得到“第二类”这个结果

case when col_1 in ('a','b') then '第一类'
     when col_1 in ('a') then '第二类'
     else '其他' end

实例演示:

首先创建一张users表,其中包含id,name,sex三个字段,表内容如下:

select * from users
 
 ID        NAME                 SEX
---------- -------------------- ----------
1          张一                 
2          张二                 1
3         张三                 
4          张四                
5          张五                 2
6          张六                 1
7          张七                 2
8          张八                 1

1、上表结果中的"sex"是用代码表示的,希望将代码用中文表示。可在语句中使用case语句:

select u.id,u.name,u.sex,
   (case u.sex
      when 1 then '男'
      when 2 then '女'
      else '空的'
      end
     )性别
  from users u;
                                    ID NAME                        SEX 性别
--------------------------------------- -------------------- ---------- ------
                                      1 张一                            空的
                                      2 张二                          1 男
                                      3 张三                            空的
                                      4 张四                            空的
                                      5 张五                          2 女
                                      6 张六                          1 男
                                      7 张七                          2 女
                                      8 张八                          1 男

2、如果不希望列表中出现"sex"列,语句如下:

select u.id,u.name,
    (case u.sex
      when 1 then '男'
      when 2 then '女'
      else '空的'
      end
    )性别
  from users u;
 
                                     ID NAME                 性别
--------------------------------------- -------------------- ------
                                      1 张一                 空的
                                      2 张二                 男
                                      3 张三                 空的
                                      4 张四                 空的
                                      5 张五                 女
                                      6 张六                 男
                                      7 张七                 女
                                      8 张八                 男

3、将sum与case结合使用,可以实现分段统计。

如果现在希望将上表中各种性别的人数进行统计,sql语句如下:

select
    sum(case u.sex when 1 then 1 else 0 end)男性,
    sum(case u.sex when 2 then 1 else 0 end)女性,
    sum(case when u.sex <>1 and u.sex<>2 then 1 else 0 end)性别为空
  from users u;
 
        男性         女性       性别为空
---------- ---------- ----------
         3          2          0
 
--------------------------------------------------------------------------------
SQL> select
    count(case when u.sex=1 then 1 end)男性,
    count(case when u.sex=2 then 1 end)女,
    count(case when u.sex <>1 and u.sex<>2 then 1 end)性别为空
  from users u;
 
        男性          女       性别为空
---------- ---------- ----------
         3          2          0

以上就是sql中case when的用法的详细内容,更多请关注php中文网其它相关文章!

php中文网最新课程二维码
  • 相关标签:sql case when 用法
  • 本文原创发布php中文网,转载请注明出处,感谢您的尊重!
  • 相关文章

    相关视频


    网友评论

    文明上网理性发言,请遵守 新闻评论服务协议

    我要评论
  • mysql case when是:1、作简单搜索,语为【CASE [col_name] WHEN [value1]】;2、作搜索函数,语为【ASE WHEN [expr] THEN [result1
    mysql case when:1、简单函数 , 枚举这个字段所有可能值,代码为【CASE [col_name]WHEN value1]】;2、搜索函数,可以写判断且只会返回第一个符合条件值,代码为

    2020-06-09

    1661

    sqllike利通配符把一个值与类似值进行比较,其是:1、百分号通配符,语是【WHERE SALARY LIKE '200%'】;2、百分号通配符,语是【WHERE SALARY LIKE
    C语言switch语句case后面不能是一个关系表达式,case后面跟是一个常量表达式,CASE表达式真假值判断就会止,而剩余WHEN子句会被忽略。
    c语言switch是:1、switch后面括弧内【表达式】,ANSI标准允许它为任何类型;2、当表达式值与某一个case后面常量表达式值相等时,就执行此case后面语句,否则,就执行default
    SQLselect语句结构是:“SELECT select_list [ INTO..]
    sql优化常有:1、应尽量避免全表扫描,应考虑在where及order by涉及列上建立索引;2、尽量避免在where子句对字段进行null值判断;3、慎in和not in;4、尽量避免大事务操作
    “having”是“group by”之后进行统计筛选,一般“having”会和“group by”一起使,使时要先“group by”进行分组,然后再进行“having”统计筛选,例如判断聚合函数值是否大于某一个值
    下面由golang教程栏目给大家介绍关于Go SQLQuery、Exec和Prepare使对比(附网络抓包) ,希望对需要朋友有所帮助!
    c语言“switch case”语句是判断case后面表达式和switch后面表达式是否相匹配,其语是“switch(变量表达式 ){case 常量1 :语句;break;}”。
    __init__在Python:在Python对象构造方为__init__方,该方是将对象进行初始化属性及方,使时只需将其定义在类,该方第一个参数必须为当前对象,其它参数可自定义
    Javaswitch case 语句:1、switch语句可以拥有多个case语句;2、case语句数据类型必须与变量数据类型相同,而且只能是常量或者字面常量;3、当遇到break语句时
    在Pythondivmod函数是把除数和余数运算结果结合起来,其为“divmod(a, b)”,其a和b类型都是数字类型,返回值为一个包含商和余数元组,使时该函数无需导入,可直接使
    reverse()是python列表一个内置方于反向列表元素;语:“list.reverse()”。reverse()方没有返回值,但是会对列表元素进行反向排序。
    javatoString方使:toString()方于返回以一个字符串表示Number对象值。
    Pythonreplace是:把字符串old(旧字符串)替换成new(新字符串),如果指定第三个参数max,则替换不超过max次。
    pythondel函数:如【a=1 del a】,表示删除变量a,解除a对1。由于del函数作在变量上,而不是数据对象上,所以del函数删除是变量,而不是数据。
    javafinalize方是Object类提供一个方,在GC准备释放对象所占内存空间之前,它将首先调finalize()方
    phpclone方于对象复制。对象复制通过clone关键字来完成,如【$copy_of_object = clone $object;】。对象__clone()方不能被直接调
    在python可以使“split()”函数拆分字符串,该函数于指定分隔符对字符串进行切片,并返回分割后字符串列表,其语是【split(str="",num=string.count

    专题推荐

    推荐视频教程
  • NoSql-redis基础视频教程NoSql-redis基础视频教程
  • PHP+Jquery+Mysql实现省市县三级联动PHP+Jquery+Mysql实现省市县三级联动
  • MySQL权威开发指南(教程)MySQL权威开发指南(教程)
  • MySQL高级进阶视频教程MySQL高级进阶视频教程
  • 视频教程分类