Re: [SQL ] left join表格後where的問題
SELECT *
FROM A
LEFT JOIN B ON A.ID = B.A_ID AND B.del = 0
※ 引述《beolk (藍色方塔)》之銘言:
: 資料庫名稱:MariaDB
: 資料庫版本:10.4.21-MariaDB - mariadb.org binary distribution
: 內容/問題描述:
: 各位先進好,小弟目前有AB兩張關聯表:
: A有ID、name、description等欄位,B有ID、A_ID、title、content、del等欄位。
: del是邏輯刪除的欄位,如果del為1的話代表這筆紀錄已經被使用者刪除看不到。
: 我希望當對應B的紀錄(del=1)或無對應紀錄(del is null)時僅顯示A,
: 若對應B的紀錄(del=0)時同時顯示A跟B。
: 有嘗試過下面這種寫法:
: SELECT A.*, B.*
: FROM A
: LEFT JOIN B ON A.ID = B.A_ID
: WHERE B.del = 0 OR B.del IS NULL
: 可以成功在沒有對應B紀錄時候撈出A,以及del=0時的A與B,
: 但是如果有一筆A只對應到del=1的B紀錄時,上面的寫法就撈不出這筆A了。
: 請教各位先進該如何修改我的SQL,謝謝。
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 165.225.116.212 (香港)
※ 文章網址: https://www.ptt.cc/bbs/Database/M.1682557333.A.B6B.html
→
04/28 00:56,
1年前
, 1F
04/28 00:56, 1F
→
04/28 02:11,
1年前
, 2F
04/28 02:11, 2F
討論串 (同標題文章)
本文引述了以下文章的的內容:
完整討論串 (本文為第 2 之 2 篇):
Database 近期熱門文章
PTT數位生活區 即時熱門文章