PostgreSQL LEFT JOIN:意外的行數乘法
使用多個 LEFT JOIN 的 PostgreSQL 9.1 查詢意外地增加了行數,而不是保留它們。 該查詢旨在檢索用戶 ID、帳戶餘額、雜貨店訪問計數和魚市訪問計數。 有缺陷的查詢導致計數不正確,顯示重複值而不是實際計數。
此問題是由 PostgreSQL 從左到右的 JOIN 處理順序引起的。 後續聯結會複製早期聯接中的行,導致計數膨脹。例如,如果訪問雜貨店 3 次,魚市訪問 12 次,則結果錯誤地顯示每次訪問 12 個條目,而不是預期的 3 個和 12 個。
解決方案包括在加入之前預先匯總訪問次數。 這避免了行乘法問題。更正後的查詢是:
<code class="language-sql">SELECT u.id, u.account_balance, g.grocery_visits, f.fishmarket_visits FROM users u LEFT JOIN ( SELECT user_id, count(*) AS grocery_visits FROM grocery GROUP BY user_id ) g ON g.user_id = u.id LEFT JOIN ( SELECT user_id, count(*) AS fishmarket_visits FROM fishmarket GROUP BY user_id ) f ON f.user_id = u.id ORDER BY u.id;</code>
此修改後的查詢正確傳回每個使用者存取雜貨店和魚市的個人計數,解決了乘法問題。 例如,如果使用者造訪了 3 次雜貨店和 4 次魚市,輸出會準確反映這一點,避免原始查詢中出現的錯誤重複。
以上是為什麼我的 PostgreSQL LEFT JOIN 查詢會乘以計數而不是保留它們?的詳細內容。更多資訊請關注PHP中文網其他相關文章!