not in和not exist的区别
来源:互联网 发布:东华大数据 编辑:程序博客网 时间:2024/05/16 17:29
今天写了一个简单的NOT IN语句,结果跟预期大相径庭,百度之发现深坑一个,遂录之。
登陆账户表logins
联系人表contacts
contacts表的logins_code连接logins表的code,联系人可以绑定一个登陆用户,也可以不绑定,我们需要查logins获得没有绑定的账户,sql语句:
SELECT * FROM logins WHERE code NOT IN(SELECT logins_code FROM contacts);
预期应该是获得 c|member|N 的记录,但结果是Empty set.
SELECT logins_code FROM contacts;
返回的结果是(a,b,null),继续前推:
SELECT * FROM logins WHERE code NOT IN ('a','b',NULL);等同于SELECT * FROM logins WHERE code<>'a' AND code<>'b' AND code<>NULL;
MySQL的IN并不完全等同于多个OR条件子句,MySQL是将IN()列表中的数据先排序后二分查找。
问题出现了,在SQL中 =,!=,~=,^=,<> 与 NULL 比较的结果都是FALSE,与NULL值比较的时候必须用IS NULL ,IS NOT NULL。如果你数据库中的字段都是默认为NULL,那你就要小心了,如果对查询做了一个判断,例如我上面code 为f的记录
SELECT * FROM contacts where logins_code='';
还是什么都查不到,应该是logins_code IS NULL
所以如果你表字段默认为NULL在进行判断的时候一定要长点心了,NOT IN的坑算是对这个判断做了个包装。
最后还是通过EXISTS解决了问题,
SELECT * FROM logins t1 WHERE NOT EXISTS (SELECT * FROM contacts t2 WHERE t1.code=t2.logins_code);
我还没打算解释这个为什么可以,因为我看到一个巨绕的文章,正在研究,待议~
0 0
- not in和not exist的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist,not in 与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- in与exist , not in与not exist 的区别
- java思维导图
- Ant Junit任务整合
- jquery ajax()请求成功,在控制台可以看到返回的数据,但是回调函数中却取不到数据
- 【鸟哥Linux】Linux文件与目录管理
- 关于JAVA的selenium安装使用
- not in和not exist的区别
- Mark Down学习(二) 效果
- ssh使用无密码登陆
- 上机 客房服务
- 用卷积神经网络检测脸部关键点的教程(一)环境配置与浅层网络训练
- ubuntu搜狗输入法切换快捷键fcitx设置
- 全平台chrome添加ublock-origin拓展程序
- 良好的接口设计不需要潜规则
- 显式意图和隐式意图和菜单