qh_QH
2019-04-28 12:51Oracel SQL查询的一些问题
小弟最近查Oracel数据库时遇到点问题,希望热心网友能指点下我
问题如下!
有表A和表B,两张表都只有字段名:name,没有主键,表A数据10万,表B数据12万。现查询表A中有多少个name和表B的name一样,有多少不一样,SQL如下
--查询name相同个数,记SQL1
select count(*) from(
select distinct name from A
where A.name in (select distinct B.name from B))
--查询name不同个数,记SQL2
select count(*) from(
select distinct name from A
where A.name not in (select distinct B.name from B))
执行以上两条sql,发现SQL1查询总数8万,但是SQL2查询总数是0条记录(SQL2按理说是4万条记录才对呀)
--SQL2改写,记SQL3
select count(*)
(select distinct C.name from A C
where C.name not int
( select distinct name from A
where A.name in (select distinct B.name from B))
执行SQL3,这样查询结果是4万条记录,请问各位,为什么执行SQL2返回的是0条记录呀?
- 点赞
- 回答
- 收藏
- 复制链接分享
3条回答
为你推荐
- Oracle 如何查询某个字段不符合日期规范的值
- sql
- oracle
- 2个回答
- oracle sql WM_CONCAT函数
- sql
- oracle
- 2个回答
- oracle sql语句按条件查找
- sql
- oracle
- 6个回答
- oracle sql优化的问题 各位大神有什么办法优化一下吗
- sql
- 优化
- oracle
- 8个回答
- Oracle的SQL语句优化(子查询多,查询出来的字段也多的情况)
- sql
- 优化
- oracle
- 索引
- 1个回答
换一换