NOT IN使用注意事项
发布时间:2021-01-07 15:36:52 所属栏目:MySql教程 来源:网络整理
导读:以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考 下午被一条SQL折磨了select EMP_ID,EMP_NUM,NAME from employee WHERE emp_id in ( select distinct E.emp_id from EMPLOYEE E INNER JOIN PROJECT_EMPLOYEE pe on e
|
以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考 下午被一条SQL折磨了
select EMP_ID,EMP_NUM,NAME
from employee
WHERE
emp_id in
(
select distinct E.emp_id
from EMPLOYEE E
INNER JOIN PROJECT_EMPLOYEE pe on e.emp_id = pe.emp_id
INNER JOIN PROJECT p on pe.pro_id = p.pro_id
where pe.pro_id ='B49CBE19481447A68445461E7BE02B13'
);//3条数据
因为业务上有变更,需要在此SQL基础上加上一些其他限制,修改后的SQL:
select EMP_ID,NAME
from employee
WHERE
emp_id in
(
select distinct E.emp_id
from EMPLOYEE E
INNER JOIN PROJECT_EMPLOYEE pe on e.emp_id = pe.emp_id
INNER JOIN PROJECT p on pe.pro_id = p.pro_id
where pe.pro_id ='B49CBE19481447A68445461E7BE02B13'
and e.emp_id not in (select s.emp_id from salesteam s )
);//0条数据,把not in 改成in有1条数据
纠结很久,发现是因为not in 后面的查询条件select s.emp_id from salesteam s所返回的数据中存在null的原因
解决办法就是将not in的子查询中加上is not null的条件
select s.emp_id from salesteam s where s.emp_id is not null
以上内容由PHP站长网【52php.cn】收集整理供大家参考研究 如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。 (编辑:应用网_阳江站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
站长推荐

