Verschachtelte SQL-Joins: INNER JOINs und OUTER JOINs
Hebt ein INNER JOIN
nach einem OUTER JOIN
die Wirkung des OUTER JOIN
auf? Und sollten INNER JOIN
s in Multi-Join-Abfragen immer vor OUTER JOIN
s stehen?
Die Antwort ist differenziert. Ein nachfolgendes INNER JOIN
negiert das OUTER JOIN
nur, wenn seine ON
-Klausel das Vorhandensein von Spalten erfordert, die aufgrund des NULL
OUTER JOIN
sein könnten. Durch einfaches Neuanordnen der Verknüpfungen lässt sich das Problem nicht beheben. Sie müssen das INNER JOIN
in ein passendes OUTER JOIN
ändern.
Lassen Sie uns veranschaulichen:
Beispiel 1 (Nachbestellung spielt keine Rolle):
SELECT * FROM person LEFT JOIN address ON person.address_id = address.id INNER JOIN email ON person.email_id = email.id
Hier ändert eine Neuordnung der Verknüpfungen nichts an den Ergebnissen.
Beispiel 2 (Angelegenheiten neu anordnen):
SELECT * FROM person LEFT JOIN address ON person.address_id = address.id INNER JOIN city ON address.city_id = city.id
Die zweite ON
-Klausel erfordert ein Nicht-NULL
address.city_id
. Dadurch wird das LEFT OUTER JOIN
außer Kraft gesetzt und person
-Datensätze ohne passendes city
über address
herausgefiltert. Um dies zu korrigieren, ersetzen Sie das INNER JOIN
durch ein LEFT OUTER JOIN
.
Best Practices:
Obwohl dies nicht unbedingt vorgeschrieben ist, wird im Allgemeinen empfohlen, INNER JOIN
s vor OUTER JOIN
s zu platzieren. Dies verbessert die Lesbarkeit und verdeutlicht die wesentlichen Filterbedingungen der Abfrage. Darüber hinaus werden RIGHT OUTER JOIN
s oft weniger bevorzugt und können für eine bessere Klarheit und Wartbarkeit normalerweise mit LEFT OUTER JOIN
s umgeschrieben werden.
Das obige ist der detaillierte Inhalt vonNegiert ein INNER JOIN nach einem OUTER JOIN den Effekt des OUTER JOIN?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

In dem Artikel werden mithilfe der Änderungstabelle von MySQL Tabellen, einschließlich Hinzufügen/Löschen von Spalten, Umbenennung von Tabellen/Spalten und Ändern der Spaltendatentypen, erläutert.

In Artikel werden die Konfiguration der SSL/TLS -Verschlüsselung für MySQL, einschließlich der Erzeugung und Überprüfung von Zertifikaten, erläutert. Das Hauptproblem ist die Verwendung der Sicherheitsauswirkungen von selbstsignierten Zertifikaten. [Charakterzahl: 159]

In Artikel werden Strategien zum Umgang mit großen Datensätzen in MySQL erörtert, einschließlich Partitionierung, Sharding, Indexierung und Abfrageoptimierung.

In Artikel werden beliebte MySQL -GUI -Tools wie MySQL Workbench und PhpMyAdmin beschrieben, die ihre Funktionen und ihre Eignung für Anfänger und fortgeschrittene Benutzer vergleichen. [159 Charaktere]

In dem Artikel werden in MySQL die Ablagerung von Tabellen mithilfe der Drop -Tabellenerklärung erörtert, wobei Vorsichtsmaßnahmen und Risiken betont werden. Es wird hervorgehoben, dass die Aktion ohne Backups, die Detaillierung von Wiederherstellungsmethoden und potenzielle Produktionsumfeldgefahren irreversibel ist.

In Artikeln werden ausländische Schlüssel zur Darstellung von Beziehungen in Datenbanken erörtert, die sich auf Best Practices, Datenintegrität und gemeinsame Fallstricke konzentrieren.

In dem Artikel werden in verschiedenen Datenbanken wie PostgreSQL, MySQL und MongoDB Indizes für JSON -Spalten in verschiedenen Datenbanken erstellt, um die Abfrageleistung zu verbessern. Es erläutert die Syntax und die Vorteile der Indizierung spezifischer JSON -Pfade und listet unterstützte Datenbanksysteme auf.

Artikel erläutert die Sicherung von MySQL gegen SQL-Injektions- und Brute-Force-Angriffe unter Verwendung vorbereiteter Aussagen, Eingabevalidierung und starken Kennwortrichtlinien (159 Zeichen).


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

DVWA
Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.