Maison base de données SQL Instructions couramment utilisées des déclencheurs SQL (résumé)

Instructions couramment utilisées des déclencheurs SQL (résumé)

Nov 23, 2019 pm 05:25 PM
sql 触发器

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.

Instructions couramment utilisées des déclencheurs SQL (résumé)

1. Créez un déclencheur simple

CREATE TRIGGER 触发器名称
ON 表名
FOR INSERT、UPDATE 或 DELETE
AS
    T-SQL 语句
Copier après la connexion

Remarque : le nom du déclencheur n'est pas cité.

2. Supprimer les déclencheurs

drop trigger 触发器名称
Copier après la connexion

Supprimer plusieurs déclencheurs :

drop trigger 触发器名称,触发器名称
Copier après la connexion

Renommer les déclencheurs

Renommer avec Query Analyzer

exec sp_rename 原名称, 新名称
Copier après la connexion

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...
Copier après la connexion

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 列
Copier après la connexion

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 + '的记录')
Copier après la connexion

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 一列,我们可以看到触发器名称。
Copier après la connexion

6. sp_helptext Afficher le contenu du déclencheur

use 数据库名
go
exec sp_helptext '触发器名称'
Copier après la connexion

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
Copier après la connexion

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
Copier après la connexion

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
Copier après la connexion

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!

Déclaration de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Quelle est la différence entre HQL et SQL dans le framework Hibernate ? Apr 17, 2024 pm 02:57 PM

HQL et SQL sont comparés dans le framework Hibernate : HQL (1. Syntaxe orientée objet, 2. Requêtes indépendantes de la base de données, 3. Sécurité des types), tandis que SQL exploite directement la base de données (1. Normes indépendantes de la base de données, 2. Exécutable complexe requêtes et manipulation de données).

Utilisation de l'opération de division dans Oracle SQL Utilisation de l'opération de division dans Oracle SQL Mar 10, 2024 pm 03:06 PM

"Utilisation de l'opération de division dans OracleSQL" Dans OracleSQL, l'opération de division est l'une des opérations mathématiques courantes. Lors de l'interrogation et du traitement des données, les opérations de division peuvent nous aider à calculer le rapport entre les champs ou à dériver la relation logique entre des valeurs spécifiques. Cet article présentera l'utilisation de l'opération de division dans OracleSQL et fournira des exemples de code spécifiques. 1. Deux méthodes d'opérations de division dans OracleSQL Dans OracleSQL, les opérations de division peuvent être effectuées de deux manières différentes.

Comparaison et différences de syntaxe SQL entre Oracle et DB2 Comparaison et différences de syntaxe SQL entre Oracle et DB2 Mar 11, 2024 pm 12:09 PM

Oracle et DB2 sont deux systèmes de gestion de bases de données relationnelles couramment utilisés, chacun possédant sa propre syntaxe et ses propres caractéristiques SQL. Cet article comparera et différera la syntaxe SQL d'Oracle et de DB2, et fournira des exemples de code spécifiques. Connexion à la base de données Dans Oracle, utilisez l'instruction suivante pour vous connecter à la base de données : CONNECTusername/password@database Dans DB2, l'instruction pour vous connecter à la base de données est la suivante : CONNECTTOdataba.

Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Explication détaillée de la fonction Définir la balise dans les balises SQL dynamiques MyBatis Feb 26, 2024 pm 07:48 PM

Interprétation des balises SQL dynamiques MyBatis : explication détaillée de l'utilisation des balises Set MyBatis est un excellent cadre de couche de persistance. Il fournit une multitude de balises SQL dynamiques et peut construire de manière flexible des instructions d'opération de base de données. Parmi elles, la balise Set est utilisée pour générer la clause SET dans l'instruction UPDATE, qui est très couramment utilisée dans les opérations de mise à jour. Cet article expliquera en détail l'utilisation de la balise Set dans MyBatis et démontrera ses fonctionnalités à travers des exemples de code spécifiques. Qu'est-ce que Set tag Set tag est utilisé dans MyBati

Que signifie l'attribut d'identité dans SQL ? Que signifie l'attribut d'identité dans SQL ? Feb 19, 2024 am 11:24 AM

Qu'est-ce que l'identité en SQL ? Des exemples de code spécifiques sont nécessaires. En SQL, l'identité est un type de données spécial utilisé pour générer des nombres à incrémentation automatique. Il est souvent utilisé pour identifier de manière unique chaque ligne de données dans une table. La colonne Identité est souvent utilisée conjointement avec la colonne clé primaire pour garantir que chaque enregistrement possède un identifiant unique. Cet article détaillera comment utiliser Identity et quelques exemples de code pratiques. La manière de base d'utiliser Identity consiste à utiliser Identit lors de la création d'une table.

Comment résoudre l'erreur 5120 dans SQL Comment résoudre l'erreur 5120 dans SQL Mar 06, 2024 pm 04:33 PM

Solution : 1. Vérifiez si l'utilisateur connecté dispose des autorisations suffisantes pour accéder ou utiliser la base de données, et assurez-vous que l'utilisateur dispose des autorisations appropriées ; 2. Vérifiez si le compte du service SQL Server est autorisé à accéder au fichier spécifié ou ; dossier et assurez-vous que le compte dispose des autorisations suffisantes pour lire et écrire le fichier ou le dossier ; 3. Vérifiez si le fichier de base de données spécifié a été ouvert ou verrouillé par d'autres processus, essayez de fermer ou de libérer le fichier et réexécutez la requête ; . Essayez en tant qu'administrateur, exécutez Management Studio en tant que etc.

Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? Dec 17, 2023 am 08:41 AM

Comment utiliser les instructions SQL pour l'agrégation de données et les statistiques dans MySQL ? L'agrégation des données et les statistiques sont des étapes très importantes lors de l'analyse des données et des statistiques. En tant que puissant système de gestion de bases de données relationnelles, MySQL fournit une multitude de fonctions d'agrégation et de statistiques, qui peuvent facilement effectuer des opérations d'agrégation de données et de statistiques. Cet article présentera la méthode d'utilisation des instructions SQL pour effectuer l'agrégation de données et les statistiques dans MySQL, et fournira des exemples de code spécifiques. 1. Utilisez la fonction COUNT pour compter. La fonction COUNT est la plus couramment utilisée.

Concurrence en technologie de base de données : quelles sont les différences entre Oracle et SQL ? Concurrence en technologie de base de données : quelles sont les différences entre Oracle et SQL ? Mar 09, 2024 am 08:30 AM

Concurrence en technologie de base de données : quelles sont les différences entre Oracle et SQL ? Dans le domaine des bases de données, Oracle et SQL Server sont deux systèmes de gestion de bases de données relationnelles très respectés. Bien qu’elles appartiennent toutes deux à la catégorie des bases de données relationnelles, il existe de nombreuses différences entre elles. Dans cet article, nous examinerons les différences entre Oracle et SQL Server, ainsi que leurs fonctionnalités et avantages dans les applications pratiques. Tout d'abord, il existe des différences de syntaxe entre Oracle et SQL Server.

See all articles