首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >SQL从表A中选择在表B中没有行的行

SQL从表A中选择在表B中没有行的行
EN

Stack Overflow用户
提问于 2011-04-02 17:25:58
回答 5查看 408关注 0票数 0
代码语言:javascript
运行
复制
table A      table B
----------   ---------
id name      a_id
1  Chris     1
2  Steve
3  Allen

选择A中id没有出现在表B中的所有行的正确sql查询是什么?

代码语言:javascript
运行
复制
Returns: 2 Steve, 3 Allen
EN

回答 5

Stack Overflow用户

发布于 2011-04-02 17:29:14

有正确的方法,也有容易理解的方法。任何还算不错的sql引擎都会在后端把它们变成同样的东西,所以我总是用简单的方式来写这个:

select * from A where id not in (select a_id from B)

票数 1
EN

Stack Overflow用户

发布于 2011-04-02 17:30:22

代码语言:javascript
运行
复制
select 
  A.id,  
  A.Name  
from A   
  left join B on A.id = B.A_id  
where 
  B.A_id is null
票数 1
EN

Stack Overflow用户

发布于 2011-04-02 19:01:25

代码语言:javascript
运行
复制
SELECT *
FROM TableA
WHERE id IN (
  SELECT id
  FROM TableA
  EXCEPT
  SELECT a_id
  FROM TableB
)
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/5522342

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档