Heim > Datenbank > MySQL-Tutorial > Ist die Verwendung von „OR' in INNER JOIN-Bedingungen immer schlecht für die SQL-Leistung?

Ist die Verwendung von „OR' in INNER JOIN-Bedingungen immer schlecht für die SQL-Leistung?

Barbara Streisand
Freigeben: 2025-01-10 19:01:41
Original
643 Leute haben es durchsucht

Is Using

SQL INNER JOIN mit OR: Leistungsengpass

Bei einem kürzlich durchgeführten Versuch zur Leistungsoptimierung wurde ein erhebliches Problem hervorgehoben: die Verwendung des OR-Operators innerhalb einer INNER JOIN-Bedingung. Die folgende Abfrage veranschaulicht das Problem:

<code class="language-sql">SELECT mt.ID, mt.ParentID, ot.MasterID
FROM dbo.MainTable AS mt
INNER JOIN dbo.OtherTable AS ot ON ot.ParentID = mt.ID OR ot.ID = mt.ParentID</code>
Nach dem Login kopieren

Diese Abfrage erwies sich als langsam. Umschreiben mit LEFT JOINs dramatisch verbesserter Leistung:

<code class="language-sql">SELECT mt.ID, mt.ParentID,
   CASE WHEN ot1.MasterID IS NOT NULL THEN ot1.MasterID ELSE ot2.MasterID END AS MasterID
FROM dbo.MainTable AS mt
LEFT JOIN dbo.OtherTable AS ot1 ON ot1.ParentID = mt.ID
LEFT JOIN dbo.OtherTable AS ot2 ON ot2.ID = mt.ParentID
WHERE ot1.MasterID IS NOT NULL OR ot2.MasterID IS NOT NULL</code>
Nach dem Login kopieren

Die überarbeitete Abfrage wurde in Sekundenschnelle ausgeführt, eine wesentliche Verbesserung. Dies wirft Bedenken hinsichtlich der allgemeinen Verwendung von OR in JOIN-Bedingungen auf.

Warum OR in JOINs langsam sein können

Das Kernproblem besteht darin, dass OR unter JOIN-Bedingungen verhindert, dass der SQL Server-Optimierer effiziente HASH- oder MERGE-Joins verwendet. Diese optimierten Join-Methoden sind in der Regel für eine schnelle Abfrageausführung von entscheidender Bedeutung. Die OR-Bedingung verhindert, dass der Server die Äquivalenz der Abfrage zu zwei separaten Equijoins erkennt:

<code class="language-sql">SELECT *
FROM maintable m
JOIN othertable o ON o.parentId = m.id
UNION
SELECT *
FROM maintable m
JOIN othertable o ON o.id = m.parentId</code>
Nach dem Login kopieren

Dies zwingt SQL Server dazu, einen weniger effizienten Ausführungsplan zu wählen, was zu einer langsameren Leistung führt.

Best Practices: Vermeiden Sie OR unter JOIN Bedingungen

Die Verwendung von OR unter JOIN-Bedingungen ist zwar nicht streng verboten, behindert jedoch häufig die Optimierung und führt zu Leistungseinbußen. Bei mehreren Join-Bedingungen bieten separate Equijoins (wie oben mit der Anweisung LEFT JOIN und UNION oder LEFT JOIN mit CASE gezeigt) im Allgemeinen eine bessere Leistung. Dadurch kann der Abfrageoptimierer seine effizientesten Algorithmen nutzen.

Das obige ist der detaillierte Inhalt vonIst die Verwendung von „OR' in INNER JOIN-Bedingungen immer schlecht für die SQL-Leistung?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage