为了账号安全,请及时绑定邮箱和手机立即绑定

使用SQLite进行完全外部联接

使用SQLite进行完全外部联接

湖上湖 2019-12-27 09:50:38
SQLite仅具有INNER和LEFT JOIN。有没有办法用SQLite进行完全外部联接?
查看完整描述

3 回答

?
至尊宝的传说

TA贡献1789条经验 获得超10个赞

是的,请参阅Wikipedia上的示例。


SELECT employee.*, department.*

FROM   employee 

       LEFT JOIN department 

          ON employee.DepartmentID = department.DepartmentID

UNION ALL

SELECT employee.*, department.*

FROM   department

       LEFT JOIN employee

          ON employee.DepartmentID = department.DepartmentID

WHERE  employee.DepartmentID IS NULL


查看完整回答
反对 回复 2019-12-27
?
一只斗牛犬

TA贡献1784条经验 获得超2个赞

在乔纳森·莱夫勒(Jonathan Leffler)评论之后,这是马克·拜尔斯(Mark Byers)的另一种答案:


SELECT * FROM table_name_1 LEFT OUTER JOIN table_name_2 ON id_1 = id_2

UNION

SELECT * FROM table_name_2 LEFT OUTER JOIN table_name_1 ON id_1 = id_2

请参阅此处以获取原始源代码和其他SQLite示例。


查看完整回答
反对 回复 2019-12-27
?
白板的微信

TA贡献1883条经验 获得超3个赞

如果使用UNION ALL,则两个选择之一必须排除“内部联接”行,例如所示的WHERE条件,这一点至关重要。或者,您可以使用普通的UNION并消除其重复,以避免重复“内部联接”行。

查看完整回答
反对 回复 2019-12-27
  • 3 回答
  • 0 关注
  • 652 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信