• GaussDB SQL基础语法示例-常见的条件表达式


    目录

    一、前言

    二、条件表达式的概念及GaussDB中的常见条件表达式

    三、GaussDB中常用的条件表达式(语法 + 示例)

    1、CASE表达式

    2、DECODE表达式

    3、COALESCE表达式

    4、NULLIF表达式

    5、GREATEST/ LEAST表达式

    6、NVL表达式

    四、小结

    一、前言

    SQL是用于访问和处理数据库的标准计算机语言。GaussDB支持SQL标准(默认支持SQL2、SQL3和SQL4的主要特性)。

    本系列将以《云数据库GaussDB—SQL参考》为主线进行介绍。

    二、条件表达式的概念及GaussDB中的常见条件表达式

    条件表达式是指在数据库中进行SQL语句查询时,根据特定条件筛选出符合要求的数据所使用的表达式。 在GaussDB数据库中,CASE、DECODE、COALESCE、NULLIF、GREATEST和NVL等都是常用的条件表达式。

    • CASE根据条件进行多分支判断,根据不同的条件返回不同的结果。
    • DECODEGaussDB数据库提供的函数功能,相当于SQL语言中的IF-THEN-ELSE语句,根据第一个参数和后续参数进行比较,返回符合条件的结果。
    • COALESCE返回第一个非空的参数值。如果所有参数都为空,那么就会返回NULL。COALESCE不会计算不需要用来判断结果的参数;即在第一个非空参数右边的参数不会被计算。
    • NULLIF用于比较两个字段的值,如果它们相等,则返回NULL,否则返回第一个字段的值。要求两个表达式数据类型一致。
    • GREATEST用于返回多个数字值中的最大值。
    • NVL接受两个参数,如果第一个参数为空,则返回第二个参数的值;如果第一个参数不为空,则返回第一个参数的值。

    下文将逐一进行介绍。

    三、GaussDB中常用的条件表达式(语法 + 示例)

    1、CASE表达式

    1)语法:

    CASE WHEN condition1 THEN result1

               WHEN condition2 THEN result2

               ……

               ELSE result

     END

    说明:根据条件进行多分支判断,根据不同的条件返回不同的结果。

    • 如果结果为真,CASE表达式的结果就是符合该条件所对应的result。
    • 如果结果为假,则以相同方式处理随后的WHEN或ELSE子句。
    • 如果各WHEN condition都不为真,表达式的结果就是在ELSE子句执行的result。如果省略了ELSE子句且没有匹配的条件,结果为NULL。

    2)示例:

    SELECT name

                  ,age

                  ,CASE

                             WHEN age < 18 THEN '未成年'

                             WHEN age >= 18 AND age < 60 THEN '成年'

                             ELSE '老年'

                   END AS age_group

    FROM company;

    解析:

    这段代码主要是从 "company" 表中选择 "name" 和 "age" 数据,并通过“CASE表达式”为每个用户生成一个根据年龄划分的组别('未成年'、'成年' 或 '老年')。

    另参见,前面的文章《GaussDB SQL基本语法示例-CASE表达式》

    2、DECODE表达式

    1)语法:

    DECODE(base_expression,compare1,value1,compare(n),value(n),default)

    说明:GaussDB数据库提供的函数功能,相当于IF-THEN-ELSE语句,根据第一个参数和后续参数进行比较,返回符合条件的结果。

    2)示例:

    SELECT name

                  ,salary

                  ,DECODE(salary, NULL, '未知', 5000, '初级标准线', 20000, '中级标准线',30000, '高级级标准线', '其他') AS salary_level

    FROM company ORDER BY salary ;

    解析:

    这段代码的目的是从 "company" 表中选择 "name" 和 "salary" 数据,并通过“DECODE表达式”定义工资级别('未知'、'初级标准线'、'中级标准线'、 '高级标准线'、‘其他’)。

    3、COALESCE表达式

    1)语法:

    COALESCE(value1,value2,…)

    说明:返回第一个非空的参数值。如果所有参数都为空,那么就会返回NULL。COALESCE不会计算不需要用来判断结果的参数;即在第一个非空参数右边的参数不会被计算。

    2)示例:

    SELECT name

                  ,COALESCE(address, '未知地址') AS address

    FROM company;

    解析:这个查询将返回每个员工的名字和地址,通过“表达式COALESCE”判断,如果地址未知,它将显示 '未知地址'。

    4、NULLIF表达式

    1)语法:

    NULLIF(value1,value2)

    说明:用于比较两个字段的值,如果它们相等,则返回NULL,否则返回第一个字段的值。要求两个表达式数据类型一致。

    2)示例:

    SELECT NULLIF('abc', 'abc'); -- 返回NULL

    SELECT NULLIF('abc', '123'); -- 返回'123'

    5、GREATEST/ LEAST表达式

    1)语法:

    GREATEST(value1,value2,…)

    LEAST(value1,value2,…)

    说明:GREATEST用于返回多个数字值中的最大值。LEAST,从一个任意数字表达式的列表里选取最小的数值。以上的数字表达式必须都可以转换成一个普通的数据类型。

    2)示例:

    SELECT GREATEST(10, 20, 30); -- 返回30

    SELECT LEAST(10, 20, 30); -- 返回10

    6、NVL表达式

    1)语法:

    NVL(value1,value2,…)

    说明:接受两个参数,如果第一个参数为空,则返回第二个参数的值;如果第一个参数不为空,则返回第一个参数的值,参数类型必须一致。

    2)示例:

    SELECT name

                  ,salary

                  ,NVL(salary,default_salary) AS d_salary

    FROM company;

    解析:这个查询将返回每个员工的名字和薪水,通过“表达式NVL”判断,如果salary为空,则用取默认的default_salary 。

    四、小结

    条件表达式是数据库查询中非常有用的工具,今天介绍的CASE、DECODE、COALESCE、NULLIF、GREATEST和NVL等,在GaussDB数据库中是非常常用的,通过使用这些条件表达式,我们可以更加灵活地对数据进行查询和操作,提高程序的效率和可读性。同时,它们也使得数据的处理更为方便和快捷,为数据分析和决策提供了有力的支持。

    --结束

  • 相关阅读:
    【无标题】
    Android内存优化内存抖动的解决实战
    关于图像的读取及处理等
    基于Matlab实现多因子选股模型(附上源码+数据)
    JDBC使用了哪种设计模式
    深度学习 --- stanford cs231学习笔记八(训练神经网络之dropout)
    ubuntu系统简单尝试
    金仓数据库 Oracle至KingbaseES迁移最佳实践(2. 概述)
    android.bp文件禁用oat 优化
    vscode远程连接ubuntu
  • 原文地址:https://blog.csdn.net/GaussDB/article/details/134112332