• MySQL教程55-MySQL比较运算符


    当使用 SELECT 语句进行查询时,MYSQL 允许用户对表达式的左边操作数和右边操作数进行比较,比较结果为真,则返回 1,为假则返回 0,比较结果不确定则返回 NULL。MySQL 支持的比较运算符如下表所示。

    MySQL 中的比较运算符
    运算符作用
    = 等于
    <=> 安全的等于
    <> 或者 != 不等于
    <= 小于等于
    >= 大于等于
    大于
    IS NULL 或者 ISNULL 判断一个值是否为空
    IS NOT NULL 判断一个值是否不为空
    BETWEEN AND 判断一个值是否落在两个值之间

    比较运算符可以用于比较数字、字符串和表达式的值。注意,字符串的比较是不区分大小写的。

    1) 等于运算(=)

    = 运算符用来比较两边的操作数是否相等,相等的话返回 1,不相等的话返回 0。具体的语法规则如下:

    • 若有一个或两个操作数为 NULL,则比较运算的结果为 NULL。
    • 若两个操作数都是字符串,则按照字符串进行比较。
    • 若两个操作数均为整数,则按照整数进行比较。
    • 若一个操作数为字符串,另一个操作数为数字,则 MySQL 可以自动将字符串转换为数字。

    注意:NULL 不能用于 = 比较。

    【实例1】使用 = 进行相等判断,SQL 语句如下:

    对运行结果的分析:

    • 2=2'2' =2的返回值相同,都为 1,因为在进行判断时,MySQL 自动进行了转换,把字符 '2' 转换成了数字 2。
    • 'b'='b'为相同的字符比较,因此返回值为 1。
    • 表达式1+3和表达式2+2的结果都为 4,因此结果相等,返回值为 1;
    • 由于 = 不能用于空值 NULL 的判断,因此NULL=null的返回值为 NULL。

    2) 安全等于运算符(<=>)

    <=> 操作符和 = 操作符类似,不过 <=> 可以用来判断 NULL 值,具体语法规则为:

    • 当两个操作数均为 NULL 时,其返回值为 1 而不为 NULL;
    • 而当一个操作数为 NULL 时,其返回值为 0 而不为 NULL。

    【实例2】使用 <=> 进行相等的判断,SQL 语句如下:

    3) 不等于运算符(<> 或者 !=)

    与 = 的作用相反,<> 和 != 用于判断数字、字符串、表达式是否不相等。对于 <> 和 !=,如果两侧操作数不相等,返回值为 1,否则返回值为 0;如果两侧操作数有一个是 NULL,那么返回值也是 NULL。

    【实例3】使用 <> 和 != 进行不相等的判断,SQL 语句如下:

    由结果可以看到,两个不等于运算符作用相同,都可以进行数字、字符串、表达式的比较判断。

    4) 小于等于运算符(<=)

    <= 是小于等于运算符,用来判断左边的操作数是否小于或者等于右边的操作数;如果小于或者等于,返回值为 1,否则返回值为 0;如果两侧操作数有一个是 NULL,那么返回值也是 NULL。

    【实例4】使用 <= 进行比较判断,SQL 语句如下:

    由结果可以看到:

    • 左边操作数小于或者等于右边时,返回值为 1,例如 4<=4;
    • 当左边操作数大于右边时,返回值为 0,例如“good”第 3 个位置的“o”字符在字母表中的顺序大于“god”中的第 3 个位置的“d”字符,因此返回值为0;
    • 同样,比较 NULL 值时返回 NULL。

    5) 小于运算符(<)

    < 是小于运算符,用来判断左边的操作数是否小于右边的操作数;如果小于,返回值为 1,否则返回值为 0;如果两侧操作数有一个是 NULL,那么返回值也是 NULL。

    【实例5】使用 < 进行比较判断,SQL 语句如下:

    由结果可以看到:

    • 当左边操作数小于右边时,返回值为 1,例如 1<2;
    • 当左边操作数大于右边时,返回值为 0,例如“good”第 3 个位置的“o”字符在字母表中的顺序大于“god”中的第 3 个位置的“d”字符,因此返回值为 0;
    • 同样,比较 NULL 值时返回 NULL。

    6) 大于等于运算符(>=)

    >= 是大于等于运算符,用来判断左边的操作数是否大于或者等于右边的操作数;如果大于或者等于,返回值为 1,否则返回值为 0;如果两侧操作数有一个是 NULL,那么返回值也是 NULL。

    【实例6】使用 >= 进行比较判断,SQL 语句如下:

    由结果可以看到:

    • 左边操作数大于或者等于右边时,返回值为 1,例如 4>=4;
    • 当左边操作数小于右边时,返回值为 0,例如 1>=2;
    • 同样,比较 NULL 值时返回 NULL。

    7) 大于运算符(>)

    > 是大于运算符,用来判断左边的操作数是否大于右边的操作数;如果大于,返回值为 1,否则返回值为 0;如果两侧操作数有一个是 NULL,那么返回值也是 NULL。

    【实例7】使用 > 进行比较判断,SQL 语句如下:

    由结果可以看到:

    • 左边操作数大于右边时,返回值为 1,例如 5.5>5;
    • 当左边操作数小于右边时,返回 0,例如 1>2;
    • 同样,比较 NULL 值时返回 NULL。

    8) IS NULL(ISNULL) 和 IS NOT NULL 运算符

    IS NULL 或 ISNULL 运算符用来检测一个值是否为 NULL,如果为 NULL,返回值为 1,否则返回值为 0。ISNULL 可以认为是 IS NULL 的简写,去掉了一个空格而已,两者的作用和用法都是完全相同的。

    IS NOT NULL 运算符用来检测一个值是否为非 NULL,如果是非 NULL,返回值为 1,否则返回值为 0。

    【实例8】使用 IS NULL、ISNULL 和 IS NOT NULL 判断 NULL 值和非 NULL 值,SQL 语句如下:

    由结果可以看到,IS NULL 和 ISNULL 的作用相同,只是写法略有不同。ISNULL 和 IS NOT NULL 的返回值正好相反。

    9) BETWEEN AND 运算符

    BETWEEN AND 运算符用来判断表达式的值是否位于两个数之间,或者说是否位于某个范围内,它的语法格式如下:

    expr BETWEEN min AND max

    expr 表示要判断的表达式,min 表示最小值,max 表示最大值。如果 expr 大于等于 min 并且小于等于 max,那么返回值为 1,否则返回值为 0。

    【实例9】使用 BETWEEN AND 进行值区间判断,输入 SQL 语句如下:

    由结果可以看到:

    • 4 在端点值区间内或者等于其中一个端点值,BETWEEN AND 表达式返回值为 1;
    • 12 并不在指定区间内,因此返回值为 0;
    • 对于字符串类型的比较,按字母表中字母顺序进行比较,“x”不在指定的字母区间内,因此返回值为 0,而“b”位于指定字母区间内,因此返回值为 1。

    总结

    使用比较运算符时需要注意空值 NULL,大部分比较运算符遇到 NULL 时也会返回 NULL,上面我们都进行了说明。

  • 相关阅读:
    在页面中控制媒体流的起播点和播放长度
    缓冲区数据转换为字符串输出
    编程中注意的一个问题
    一个整合SQL语句的类
    注意服务器系统日期对防病毒软件的影响
    网络病毒源的排查(2005年3月22日维护记录)
    升级到 Microsoft .NET >Visual Basic 6.0 控件和 .NET 控件的区别
    修改您的站点设计以改善下载体验
    下一版本Windows&reg; CE 开发工具Smart Device Extensions for Microsoft Visual Studio&reg; .NET
    WINDOWS (服务器) 和 DOS(客户端) 网络互连 基于TCP/IP的编程实现
  • 原文地址:https://www.cnblogs.com/no-celery/p/13527791.html
Copyright © 2020-2023  润新知