Abrufen fehlender Daten mit „SELECT * WHERE NOT EXISTS“
Der Benutzer beabsichtigt, alle Datensätze aus der Tabelle „Mitarbeiter“ zu extrahieren, sofern angegeben Zellen sind in der Tabelle „eotm_dyn“ nicht vorhanden. Um dies zu erreichen, verwendet der Benutzer die folgende Abfrage:
SELECT * from employees WHERE NOT EXISTS (SELECT name FROM eotm_dyn)
Diese Abfrage liefert jedoch durchweg keine Ergebnisse, obwohl er weiß, dass etwa 20 Namen fehlen.
Verstehen des Problems
Der Fehler liegt darin, dass die beiden Tabellen in der Abfrage nicht verknüpft werden konnten. Derzeit wertet die Abfrage lediglich das Vorhandensein von Namen in der Tabelle „eotm_dyn“ aus, ohne auf die Tabelle „employees“ zu verweisen. Dies gibt immer „false“ zurück, es sei denn, die Tabelle „eotm_dyn“ ist leer.
Lösung: Tabellen verbinden
Um die Tabellen zu verbinden und die fehlenden Namen herauszufiltern, ändern Sie die Abfrage wie folgt:
SELECT * FROM employees e WHERE NOT EXISTS ( SELECT null FROM eotm_dyn d WHERE d.employeeID = e.id )
In dieser modifizierten Abfrage wird implizit ein LEFT JOIN zwischen den „Mitarbeitern“ durchgeführt. und „eotm_dyn“-Tabellen basierend auf dem gemeinsamen „employeeID“-Feld. Die WHERE-Klausel verwendet dann NOT EXISTS, um alle Mitarbeiterdatensätze herauszufiltern, deren Namen (oder Mitarbeiter-ID) nicht in der Tabelle „eotm_dyn“ vorhanden sind.
Alternativer Ansatz: LEFT JOIN und NULL-Werte filtern
Alternativ könnte man einen LEFT JOIN verwenden und NULL-Werte als herausfiltern folgt:
SELECT * FROM employees e LEFT JOIN eotm_dyn d ON e.employeeID = d.employeeID WHERE d.name IS NULL
Dieser Ansatz ist möglicherweise weniger effizient als die Verwendung von NOT EXISTS, bietet aber eine unkomplizierte Methode zum Abrufen der fehlenden Daten.
Das obige ist der detaillierte Inhalt vonWie kann man fehlende Mitarbeiterdatensätze mithilfe von SQL effizient abrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!