首頁 > 資料庫 > mysql教程 > 為什麼我的 PostgreSQL LEFT JOIN 查詢會乘以計數而不是保留它們?

為什麼我的 PostgreSQL LEFT JOIN 查詢會乘以計數而不是保留它們?

Linda Hamilton
發布: 2025-01-23 12:23:10
原創
412 人瀏覽過

Why Does My PostgreSQL LEFT JOIN Query Multiply Counts Instead of Preserving Them?

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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板