Maison >base de données >SQL >Instructions couramment utilisées des déclencheurs SQL (résumé)
Cet article résume quelques instructions de déclenchement SQL couramment utilisées pour tout le monde. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.
1. Créez un déclencheur simple
CREATE TRIGGER 触发器名称 ON 表名 FOR INSERT、UPDATE 或 DELETE AS T-SQL 语句
Remarque : le nom du déclencheur n'est pas cité.
2. Supprimer les déclencheurs
drop trigger 触发器名称
Supprimer plusieurs déclencheurs :
drop trigger 触发器名称,触发器名称
Renommer les déclencheurs
Renommer avec Query Analyzer
exec sp_rename 原名称, 新名称
sp_rename est une procédure stockée fournie avec SQL Server, qui est utilisée pour modifier les noms des objets créés par l'utilisateur dans la base de données actuelle, tels que les noms de tables, les listes, les noms d'index, etc. .
4. INSERT, UPDATE ou DELETE
INSTEAD OF
Exécutez l'instruction de déclenchement, mais n'exécutez pas l'instruction SQL qui déclenche le déclencheur, comme essayer de Lorsqu'un enregistrement est supprimé, l'instruction spécifiée par le déclencheur sera exécutée et l'instruction de suppression ne sera plus exécutée à ce moment. Exemple :
create trigger f on tbl instead of delete as insert into Logs...
IF UPDATE (nom de la colonne)
Vérifie si une colonne a été mise à jour. Elle est utilisée pour l'insertion ou la mise à jour et ne peut pas être utilisée pour la suppression. Exemple :
create trigger f on tbl for update as if update(status) or update(title) sql_statement --更新了 status 或 title 列
inséré, supprimé
Ce sont deux tables virtuelles insérées qui enregistrent la table formée par les enregistrements concernés après l'insertion ou la mise à jour, et supprimées qui enregistrent la table formée avant la suppression ou la mise à jour. tableau formé par les enregistrements concernés. Exemple :
create trigger tbl_delete on tbl for delete as declare @title varchar(200) select @title=title from deleted insert into Logs(logContent) values('删除了 title 为:' + title + '的记录')
Explication : Si la valeur du champ de type texte ou image est récupérée de la table virtuelle insérée ou supprimée, la valeur obtenue sera nulle.
5. Afficher tous les déclencheurs dans la base de données
use 数据库名 go select * from sysobjects where xtype='TR' sysobjects 保存着数据库的对象,其中 xtype 为 TR 的记录即为触发器对象。在 name 一列,我们可以看到触发器名称。
6. sp_helptext Afficher le contenu du déclencheur
use 数据库名 go exec sp_helptext '触发器名称'
7. . sp_helptrigger est utilisé pour afficher les attributs du déclencheur
sp_helptrigger a deux paramètres : le premier paramètre est le nom de la table ; le deuxième paramètre est le type de déclencheur, qui est char(6) ; Type, qui peut être INSERT, UPDATE ou DELETE. En cas d'omission, les propriétés de tous les types de déclencheurs dans le tableau spécifié seront affichées.
Exemple :
use 数据库名 go exec sp_helptrigger tbl
8. Récursivité, déclencheurs imbriqués
Il existe deux types de récursivité, la récursivité indirecte et la récursivité directe. Nous l'expliquons avec un exemple comme suit. Supposons qu'il y ait des tables 1 et 2 nommées respectivement T1 et T2, et qu'il y ait des bascules G1 et G2 respectivement sur T1 et T2.
Récursion indirecte : opérer sur T1 pour déclencher G1, G1 pour opérer sur T2 pour déclencher G2, G2 pour opérer sur T1 pour déclencher à nouveau G1...
Récursion directe : opérer sur T1 pour trigger G1 , G1 opère sur T1 pour déclencher à nouveau G1...
Le déclencheur imbriqué
est similaire à la récursivité indirecte. La récursivité indirecte doit former une boucle, tandis que les déclencheurs imbriqués ne doivent pas nécessairement se former. une boucle. Un anneau peut ainsi être déclenché en continu depuis T1->T2->T3..., permettant ainsi jusqu'à 32 niveaux d'imbrication.
Définir la récursion directe
Par défaut, la récursion directe est interdite. Il existe deux méthodes pour la définir pour autoriser :
T-SQL : exec sp_dboption 'dbName', '. déclencheurs récursifs', vrai
EM : Faites un clic droit sur la base de données->Propriétés->Options.
Définir la récursivité et l'imbrication indirectes
Par défaut, la récursion indirecte et l'imbrication sont autorisées. Il existe deux façons de les désactiver :
T-SQL : exec sp_configure 'les déclencheurs imbriqués. ', 0 --Le deuxième paramètre est 1, ce qui signifie qu'il est autorisé
EM : Faites un clic droit sur l'enregistrement ->Propriétés->Paramètres du serveur.
9. Déclencheur de restauration
Nous avons vu que de nombreux systèmes d'enregistrement ne peuvent pas modifier le nom d'utilisateur après l'enregistrement, mais cela est principalement déterminé par l'application si en l'ouvrant directement. la table de base de données pour apporter des modifications, vous pouvez également modifier son nom d'utilisateur en utilisant la restauration dans le déclencheur, vous pouvez intelligemment réaliser que le nom d'utilisateur ne peut pas être modifié.
use 数据库名 go create trigger tr on 表名 for update as if update(userName) rollback tran
La clé réside dans les deux dernières phrases, l'explication est la suivante : si la colonne userName est mise à jour, annulez la transaction.
10. Désactiver et activer les déclencheurs
Désactiver : modifier le nom de la table désactiver le nom du déclencheur
Activer : modifier le nom de la table activer le déclencheur Nom du déclencheur
S'il existe plusieurs déclencheurs, séparez les noms des déclencheurs par des virgules.
Si vous remplacez « Nom du déclencheur » par « TOUS », cela signifie désactiver ou activer tous les déclencheurs de la table.
11. Déterminer l'insertion, la modification et la suppression
create TRIGGER [updatetest] ON [dbo].[TEST] FOR INSERT, UPDATE, DELETE AS begin DECLARE @IsInsert bit, @IsUpdate bit, @IsDelete bit IF EXISTS(SELECT 1 FROM inserted) AND NOT EXISTS(SELECT 1 FROM deleted) SET @IsInsert = 1 ELSE SET @IsInsert = 0 IF EXISTS(SELECT 1 FROM inserted) AND EXISTS(SELECT 1 FROM deleted) SET @IsUpdate = 1 ELSE SET @IsUpdate = 0 IF NOT EXISTS(SELECT 1 FROM inserted) AND EXISTS(SELECT 1 FROM deleted) SET @IsDelete = 1 ELSE SET @IsDelete = 0 if (@IsUpdate=1) PRINT 'updated ' if (@IsInsert=1) PRINT 'insert ' if (@IsDelete=1) PRINT 'delete 'end
Apprentissage recommandé : Tutoriel MySQL
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!