「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > 右のテーブルの句でフィルタリングするときに、なぜ左結合が接続内のように見えるのですか?

右のテーブルの句でフィルタリングするときに、なぜ左結合が接続内のように見えるのですか?

2025-04-16に投稿されました
ブラウズ:951

Why Does My Left Join Act Like an Inner Join When Filtering on the Right Table's Column in the WHERE Clause?

left join conundrum:witching時間:データベースウィザードの領域で内側の結合

に変わる時間は、左結合を使用して複雑なデータ検索を実行することは一般的な慣行です。ただし、時々、左の結合が予想通りに動作しないことがあります。 A.foo、 B.BAR、 C.Foobar テーブルからaとして a.pk = b.fkのbとしてtabletwoの内側結合tabletwo B.pk = C.fkのCとしてTablethreeを左に結合します ここでa.foo = '何か' and c.foobar = 'antyelse';

興味深いことに、c.foobar条件が上記のように句に配置されると、左の結合は内側の結合に変換されるように見えます。結果は、a.fooとc.foobarの両方の基準が満たされている場合にのみ返されます。鍵は句にあります。左結合の右側からの値(On句の右側のテーブルを参照する右側)がWhere句で指定されている場合、すべてのnull値が破棄され、左結合が内側の結合に効果的に減少します。簡単に言えば、C.FoobarがTablethreeに存在しない場合、クエリには行が返されません。 c.foobar is null)

SELECT
a.foo,
b.bar,
c.foobar
FROM tableOne AS a
INNER JOIN tableTwo AS b ON a.pk = b.fk
LEFT JOIN tableThree AS c ON b.pk = c.fk
WHERE a.foo = 'something'
AND c.foobar = 'somethingelse';
c.foobar条件を結合前注:

left left join tablethree as b.pk = c.foobar = 'foolse'

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3