记一次有趣的发现:

有一个表,总记录数是1000条,现在有一条查询语句:

#查询语句1
#找出表中id中含有‘A'或‘B'或‘C'的字段
select * from table1 where id like '%A%' or id like '%B%' or id like '%C%' ;
#成功查出300条

嗯查询正常,有300条记录呢。

然后我随便再敲一次查询语句…:

#查询语句2
#找出表中id中不含有‘A'且不含有‘B'且不含有‘C'的字段
select * from table1 where id not like '%A%' and id not like '%B%' and id not like '%C%' ;
#成功查出400条

嗯查出了400条呢…什么?!只有400条??不是应该700条吗!!!

我如雷轰顶——哪里不对了??

按道理,“找出表中id中含有‘A'或‘B'或‘C'的字段” 应该等价于 “找出表中id中不含有‘A'且不含有‘B'且不含有‘C'的字段” 的啊!这是由集合运算决定的啊!

“找出表中id中含有‘A'或‘B'或‘C'的字段”看作 A∪B∪C

“找出表中id中不含有‘A'且不含有‘B'且不含有‘C'的字段”看作 "htmlcode">

#查询语句3
#找出表中id中不含有‘A'或‘B'或‘C'的字段
select * from table1 where id not in (select * from table1 where id like '%A%' or id like '%B%' or id like '%C%' );
#成功查出700条

咦??怎么这样查,才是查询语句1的互补集呢?

我将查询语句2和查询语句3得到的结果一比较,发现:原来缺少的300条记录,是id 为NULL的情况!

也就是说,not like ‘%A%' 是不能查出NULL的记录的!

经过了解,发现:

解决从集合运算到mysql的not like找不出NULL的问题

又发现了一个细节知识~

补充:注意mysql的not in查询值中存在null值时返回的查询结果会一直为空

现在有数据库表是

解决从集合运算到mysql的not like找不出NULL的问题

当我们使用这样的查询语句时:

select * from user
where username not in 
(
select username 
from user
where id != 2
)

这时子查询的结果包含了null值,所以结果会一直返回空查询,而不会返回预期的id为2这一行

解决从集合运算到mysql的not like找不出NULL的问题

我们可以稍微修改一下查询形式:

select * from user
where username not in 
(
select username 
from user
where id != 2 and username is not null
)

这时排除了username为空的列,就可以得到预期的结果了

解决从集合运算到mysql的not like找不出NULL的问题

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。

广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。