MySQL比较运算符一览表(带解析)
当使用 SELECT 语句进行查询时,MySQL 允许用户对表达式的左边操作数和右边操作数进行比较,比较结果为真,则返回 1,为假则返回 0,比较结果不确定则返回 NULL。MySQL 支持的比较运算符如下表所示。 MySQL 中的比较运算符运算符作用 = 等于 安全的等于 或者 != 不等于 = 大于等于 > 大于 IS NULL 或者 ISNULL 判断一个值是否为空 IS NOT NULL 判断一个值是否不为空 BETWEEN AND 判断一个值是否落在两个值之间 比较运算符可以用于比较数字、字符串和表达式的值。注意,字符串的比较是不区分大小写的。1) 等于运算(=)= 运算符用来比较两边的操作数是否相等,相等的话返回 1,不相等的话返回 0。具体的语法规则如下: 注意:NULL 不能用于 = 比较。 【实例1】使用 = 进行相等判断,SQL 语句如下: mysql> SELECT 1=0,'2'=2,2=2,'0.02'=0,'b'='b',(1+3)=(2+2),NULL=null; +-----+-------+-----+----------+---------+-------------+-----------+ | 1=0 | '2'=2 | 2=2 | '0.02'=0 | 'b'='b' | (1+3)=(2+2) | NULL=null | +-----+-------+-----+----------+---------+-------------+-----------+ | 0 | 1 | 1 | 0 | 1 | 1 | NULL | +-----+-------+-----+----------+---------+-------------+-----------+ 1 row in set (0.01 sec) 对运行结果的分析:2) 安全等于运算符() 操作符和 = 操作符类似,不过 可以用来判断 NULL 值,具体语法规则为: 【实例2】使用 进行相等的判断,SQL 语句如下: mysql> SELECT 10,'2'2,22,'0.02'0,'b''b',(1+3) (2+1),NULLNULL; +-------+---------+-------+------------+-----------+-----------------+-------------+ | 10 | '2'2 | 22 | '0.02'0 | 'b''b' | (1+3) (2+1) | NULLNULL | +-------+---------+-------+------------+-----------+-----------------+-------------+ | 0 | 1 | 1 | 0 | 1 | 0 | 1 | +-------+---------+-------+------------+-----------+-----------------+-------------+ 1 row in set (0.00 sec) 由结果可以看到, 在执行比较操作时和 = 的作用是相似的,唯一的区别是 可以用来对 NULL 进行判断,两者都为 NULL 时返回值为 1。3) 不等于运算符( 或者 !=)与 = 的作用相反, 和 != 用于判断数字、字符串、表达式是否不相等。对于 和 !=,如果两侧操作数不相等,返回值为 1,否则返回值为 0;如果两侧操作数有一个是 NULL,那么返回值也是 NULL。 【实例3】使用 和 != 进行不相等的判断,SQL 语句如下: mysql> SELECT 'good'<>'god',1<>2,4!=4,5.5!=5,(1+3)!=(2+1),NULL<>NULL; +---------------+------+------+--------+--------------+------------+ | 'good'<>'god' | 1<>2 | 4!=4 | 5.5!=5 | (1+3)!=(2+1) | NULL<>NULL | +---------------+------+------+--------+--------------+------------+ | 1 | 1 | 0 | 1 | 1 | NULL | +---------------+------+------+--------+--------------+------------+ 1 row in set (0.00 sec) 由结果可以看到,两个不等于运算符作用相同,都可以进行数字、字符串、表达式的比较判断。4) 小于等于运算符()> 是大于运算符,用来判断左边的操作数是否大于右边的操作数;如果大于,返回值为 1,否则返回值为 0;如果两侧操作数有一个是 NULL,那么返回值也是 NULL。 【实例7】使用 > 进行比较判断,SQL 语句如下: mysql> SELECT 'good'>'god',1>2,4>4,5.5>5,(1+3)>(2+1),NULL>NULL; +--------------+-----+-----+-------+-------------+-----------+ | 'good'>'god' | 1>2 | 4>4 | 5.5>5 | (1+3)>(2+1) | NULL>NULL | +--------------+-----+-----+-------+-------------+-----------+ 由结果可以看到:8) IS NULL(ISNULL) 和 IS NOT NULL 运算符IS NULL 或 ISNULL 运算符用来检测一个值是否为 NULL,如果为 NULL,返回值为 1,否则返回值为 0。ISNULL 可以认为是 IS NULL 的简写mssql 运算符,去掉了一个空格而已,两者的作用和用法都是完全相同的。 IS NOT NULL 运算符用来检测一个值是否为非 NULL,如果是非 NULL,返回值为 1,否则返回值为 0。 【实例8】使用 IS NULL、ISNULL 和 IS NOT NULL 判断 NULL 值和非 NULL 值,SQL 语句如下: mysql> SELECT NULL IS NULL,ISNULL(NULL),ISNULL(10),10 IS NOT NULL; +--------------+--------------+------------+----------------+ | NULL IS NULL | ISNULL(NULL) | ISNULL(10) | 10 IS NOT NULL | +--------------+--------------+------------+----------------+ | 1 | 1 | 0 | 1 | +--------------+--------------+------------+----------------+ 1 row in set (0.01 sec) 由结果可以看到,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 语句如下: mysql> SELECT 4 BETWEEN 2 AND 5,4 BETWEEN 4 AND 6,12 BETWEEN 9 AND 10; +-------------------+-------------------+---------------------+ | 4 BETWEEN 2 AND 5 | 4 BETWEEN 4 AND 6 | 12 BETWEEN 9 AND 10 | +-------------------+-------------------+---------------------+ | 1 | 1 | 0 | +-------------------+-------------------+---------------------+ 1 row in set (0.00 sec) 由结果可以看到:总结使用比较运算符时需要注意空值 NULL,大部分比较运算符遇到 NULL 时也会返回 NULL,上面我们都进行了说明。 另外,有些教程把 IN 和 NOT IN 也划分为比较运算符,但是我并不这样认为,我认为它们的初衷是判断某个值是否位于给出的列表中,只是使用了比较的功能而已,读者可以猛击《MySQL IN和NOT IN用法详解》一文了解更多。 (编辑:威海站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |