• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 众包
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
LOFLY
终其一生,编织快乐
博客园    首页    新随笔    联系   管理    订阅  订阅

SQLite Left Join

SQLite Left Join

与 INNER JOIN 子句类似,LEFT JOIN 子句是 SELECT 语句的可选子句。使用 LEFT JOIN 子句可以从多个相关表中查询数据。

假设有两个表:A和B。

  • A表有f列
  • B表有f列

为了连接A和B使用left join子句, 你将使用以下语句:

SELECT
	a,
	b
FROM
	A
LEFT JOIN B ON A.f = B.f
WHERE search_condition;

表达式 A.f = B.f 是一个条件表达式。除了等号 (=) 运算符之外,还可以使用其他比较运算符,例如大于 (>)、小于 (<) 等。

返回的结果集包括:

  1. 表 A(左表)中的行与表 B 中的行有对应关系。
  2. 如果表 A 中的行在表 B 中没有任何对应行,则表 A 中的行和表 B 中的行填充为 NULL 值。

换句话说,无论表 B 中是否有匹配的行,表 A 中的所有行都会包含在结果集中。

如果语句中包含 WHERE 子句,则在 LEFT JOIN 子句匹配完成后将应用 WHERE 子句中的 search_condition。

图示:
image

由于第二行 (a2,2) 在表 B 中没有对应行,因此 LEFT JOIN 子句会创建一个用 NULL 填充的假行。

下面的维恩图说明了 LEFT JOIN 子句。

image

SQLite Left Join例子

image

一张专辑属于一位艺术家。但是,一位艺术家可能有零张或多张专辑。

要使用 LEFT JOIN 子句查找没有任何专辑的艺术家,我们选择艺术家及其对应的专辑。如果艺术家没有任何专辑,则 AlbumId 列的值为 NULL。

为了首先显示没有任何专辑的艺术家,我们有两种选择:

  • 首先,使用 ORDER BY 子句列出 AlbumId 为 NULL 值的行。
  • 其次,使用 WHERE 子句和 IS NULL 运算符仅列出没有任何专辑的艺术家。

以下语句将 LEFT JOIN 子句与 ORDER BY 子句一起使用。

SELECT
   artists.ArtistId, 
   AlbumId
FROM
   artists
LEFT JOIN albums ON
   albums.ArtistId = artists.ArtistId
ORDER BY
   AlbumId;
SELECT
   artists.ArtistId
   , AlbumId
FROM
   artists
LEFT JOIN albums ON
   albums.ArtistId = artists.ArtistId
WHERE
   AlbumId IS NULL;

posted @ 2024-07-22 11:16  编织快乐  阅读(56)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3