MySQL对比运算符一览表分析
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; 【实例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) 由结果可以看到,两个不等于运算符作用相同,都可以进行数字、字符串、表达式的比较判断。 (编辑:站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |