若若一问:找出哪些人不是经理人

austinls 2011-07-16 12:32:35
找出哪些人是经理人的语句很简单:
select ename from emp where empno in (select mgr from emp);

可是我想用类似的句子找出哪些人不是经理人,我是这样写的:
select ename from emp where empno not in (select mgr from emp);
输出是没有命中。。。

实在不知道是什么原因。。难道是因为king那个人的mgr为null值造成的??

求解!
...全文
99 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
tangren 2011-07-16
  • 打赏
  • 举报
回复
--正确,正是null影响,你无法查询到值
--因为empno not in相当于 empno<>mgr1 and empno<>mgr2...empno<>null,肯定为false

--排除null后就可以了
SELECT ename
FROM emp
WHERE empno NOT IN (SELECT mgr FROM emp WHERE mgr IS NOT NULL);

--改写成not exists
SELECT ename
FROM emp a
WHERE NOT EXISTS (SELECT 1 FROM emp b WHERE b.mgr = a.empno);

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧