Maison >base de données >tutoriel mysql >Comment puis-je trouver les employés manquants à l'aide de l'opérateur NOT EXISTS de SQL ?

Comment puis-je trouver les employés manquants à l'aide de l'opérateur NOT EXISTS de SQL ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-11-29 09:10:15484parcourir

How Can I Find Missing Employees Using SQL's NOT EXISTS Operator?

Identification des employés manquants à l'aide de "SELECT * WHERE NOT EXISTS"

La tâche à accomplir consiste à identifier les employés d'une table (employés) dont les noms n'apparaissent pas dans une autre table (eotm_dyn). L'objectif est de récupérer une liste des salariés absents de la table eotm_dyn.

Utilisation de l'opérateur "NON EXISTE"

L'opérateur "NON EXISTE" est employé dans la requête fournie pour déterminer si un enregistrement de la table des employés ne dispose pas d'une entrée correspondante dans la table eotm_dyn. La syntaxe est la suivante :

SELECT *
FROM employees
WHERE NOT EXISTS (
    SELECT name
    FROM eotm_dyn
    WHERE employees.id = eotm_dyn.employeeID
)

Corriger l'erreur

La requête d'origine n'a renvoyé aucun résultat en raison d'une omission cruciale : l'absence de jointure entre les employés et les tables eotm_dyn. Pour remédier à cela, une condition de jointure doit être spécifiée. L'option la plus simple consiste à joindre les tables sur leur champ commun, qui semble être EmployeeID.

La requête corrigée

Incorporant la condition de jointure, la requête corrigée devient :

SELECT *
FROM employees e
WHERE NOT EXISTS (
    SELECT NULL
    FROM eotm_dyn d
    WHERE d.employeeID = e.id
)

Cette requête renverra tous les employés de la table des employés qui sont absents de la table eotm_dyn, accomplissant ainsi la tâche initiale de identifier les employés disparus.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn