Insérer un déclencheur pour SQL Server 2008
Dans SQL Server 2008, vous pouvez rencontrer un scénario dans lequel vous devez insérer des données dans une table EmployeeResult et assurez-vous que toutes les paires employé-service manquantes dans la table Employé sont automatiquement ajoutées. Pour ce faire, vous pouvez exploiter un déclencheur INSERT.
Pour définir ce déclencheur, suivez les étapes suivantes :
CREATE TRIGGER trig_Update_Employee ON [EmployeeResult] FOR INSERT AS
IF EXISTS (SELECT COUNT(*) FROM Employee WHERE ???)
Dans cette ligne, vous devez préciser la condition qui vérifie si le couple employé-service existe dans la table Employé. L'espace réservé ??? doit être remplacé par une clause qui compare les données insérées avec la table Employee.
BEGIN INSERT INTO [Employee] (Name, Department) VALUES (???, ???) END
De même, ces espaces réservés ??? doivent être remplis d'expressions qui extraient le nom et le département des données insérées.
Le déclencheur terminé peut ressembler quelque chose comme ceci :
CREATE TRIGGER trig_Update_Employee ON [EmployeeResult] FOR INSERT AS IF EXISTS (SELECT COUNT(*) FROM Employee WHERE Name = i.Name AND Department = i.Department) BEGIN INSERT INTO [Employee] (Name, Department) VALUES (i.Name, i.Department) END
Dans cet exemple, les données insérées sont représentées par l'alias "i", et la condition vérifie l'existence de la paire employé-service dans la table Employé. S'il n'existe pas, un nouvel enregistrement est inséré dans la table Employee.
En implémentant ce déclencheur, vous pouvez vous assurer que chaque fois qu'une opération INSERT se produit dans la table EmployeeResult, toutes les paires employé-service manquantes sont automatiquement ajouté à la table Employé, maintenant l'intégrité des données et éliminant les interventions manuelles.
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!