加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

MySQL对比运算符一览表分析

发布时间:2021-06-03 12:51:38 所属栏目:MySql教程 来源:互联网
导读:1) 等于运算(=)= 运算符用来比较两边的操作数是否相等,相等的话返回 1,不相等的话返回 0。具体的语法规则如下: 若有一个或两个操作数为 NULL,则比较运算的结果为 NULL。 若两个操作数都是字符串,则按照字符串进行比较。 若两个操作数均为整数,则按
1) 等于运算(=) = 运算符用来比较两边的操作数是否相等,相等的话返回 1,不相等的话返回 0。具体的语法规则如下:

若有一个或两个操作数为 NULL,则比较运算的结果为 NULL。

若两个操作数都是字符串,则按照字符串进行比较。

若两个操作数均为整数,则按照整数进行比较。

若一个操作数为字符串,另一个操作数为数字,则 MySQL 可以自动将字符串转换为数字。


注意: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=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 语句如下:

mysql> SELECT 1<=>0,'2'<=>2,2<=>2,'0.02'<=>0,'b'<=>'b',(1+3) <=> (2+1),NULL<=>NULL;
+-------+---------+-------+------------+-----------+-----------------+-------------+
| 1<=>0 | '2'<=>2 | 2<=>2 | '0.02'<=>0 | 'b'<=>'b' | (1+3) <=> (2+1) | NULL<=>NULL |
+-------+---------+-------+------------+-----------+-----------------+-------------+
|     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) 由结果可以看到,两个不等于运算符作用相同,都可以进行数字、字符串、表达式的比较判断。

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读