曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 5039|回复: 0
打印 上一主题 下一主题

[MySQL] 比较运算符

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2012-4-28 19:46:40 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在 MySQL 中一次比较的结果可能有 3 种:

1. TRUE 或 1
2. FALSE 或 0
3. NULL

比较操作既有数字比较也有字符串比较,如果待比较的值中既有数字又有字符串,那么 MySQL 会自行转换,如:


在 MySQL 的比较操作中,通常会采用下面的规则:

1.  除了安全等于(<=>)外,只要待比较的任一参数为 NULL,则比较结果为 NULL 。

2.  如果待比较的是字符串和数字,则按数字或者字符串的方式进行比较。

算术比较
算数比较包括:大于,等于,小于,等于,不等于,小于等于,大于等于,以及 MySQL 中新增的安全等于。

(1) 大于、大于等于
大于的比较规则是:若前者大于后者,则返回 1,否者返回 0 。
大于等于和大于类似,不同的是,前者和后者相等于时也返回 1。

(2) 小于、小于等于
当前者小于后者时,返回 1,否则返回 0 。
小于等于当前者等于后者时,返回1 。

(3)等于、安全等于
当两值相等时返回1,否则返回 0.
安全等于是用于 NULL 值时的判断,符号为 <=> ,增加这一项是为了保证 NULL 值的比较,如:


(4) 空值的判断
这是用于判断一个值是否为 NULL,其语句原型为 IS NULL, IS NOT NULL,具体方法如下所示:
mysql> select 1 IS NULL, 1 IS NOT NULL, 0 IS NULL, NULL IS NULL, NULL IS NOT NULL;

区间比较
在 MySQL 中可以判断一个值是否处于一个设定的区间,通常有如下几种形式:

<1> expr BETWEEN min AND max
判断 expr 的值是否大于等于 min 而小于等于 max,等价于 max >= expr >= min ,若处于这个区间,那么返回 1,否则返回 0,如下所示:


<2> expr NOT BETWEEN min AND max
和 <1> 中类似,当不属于该区间时返回 1 ,否则返回 0,使用方式如下所示:


<3> expr IN (value1, value2, ...)
比较 expr 的值是否处于集合中,若与集合中的某一值相等就返回 1 ,否则返回 0 ,使用方式如下所示:


<4> expr NOT IN (value1, value2, ...)
与 <3> 相反,当 expr 不处于集合中时返回 1 ,否则返回 0 。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2024-5-4 08:50 , Processed in 0.061408 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表