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