首頁 > 資料庫 > mysql教程 > NOT IN使用注意事项

NOT IN使用注意事项

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2016-06-07 14:55:02
原創
1424 人瀏覽過

无详细内容 无 下午被一条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 p

下午被一条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,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'
    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
登入後複製
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
我這打開出現 Not Found
來自於 1970-01-01 08:00:00
0
0
0
python3.x - Python not 運算子的問題
來自於 1970-01-01 08:00:00
0
0
0
網站首頁打不開 開啟就顯示NOT FOUND
來自於 1970-01-01 08:00:00
0
0
0
Laravel Target class [控制器名稱] does not exist.
來自於 1970-01-01 08:00:00
0
0
0
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板