IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Développement SQL Server Discussion :

Trigger sur Update et Insert


Sujet :

Développement SQL Server

  1. #1
    Rédacteur

    Avatar de Jérôme Lambert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2003
    Messages
    4 451
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2003
    Messages : 4 451
    Par défaut Trigger sur Update et Insert
    Bonjour,

    Lorsqu'on crée un Trigger qui agit sur tout Update ou Insert, comment déterminer si on a affaire à un Update ou à un Insert ?

    Je me souviens que sous Oracle, on faisait IF Inserting (je crois) mais ça n'a pas l'air de passer :s

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 998
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 998
    Billets dans le blog
    6
    Par défaut
    BOnjour,

    Les pseudo tables inserted et deleted contiennent les données :
    - avant insertion et avant modif pour inserted
    - après modif et après suppression pour deleted
    Autrement dit s'il s'agit d'une insertion, deleted ne contient aucune ligne.
    s'il s'agit d'une suppression inserted ne contient aucune ligne.
    D'ou la règle :
    1) IF EXISTS(SELECT * FROM INSERTED) AND EXISTS(SELECT * FROM DELETED) => UPDATE
    2) IF EXISTS(SELECT * FROM INSERTED) AND NOT EXISTS(SELECT * FROM DELETED) => INSERT
    3) IF NOT EXISTS(SELECT * FROM INSERTED) AND EXISTS(SELECT * FROM DELETED) => DELETE

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Rédacteur

    Avatar de Jérôme Lambert
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Novembre 2003
    Messages
    4 451
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2003
    Messages : 4 451
    Par défaut
    Impecable, un grand merci pour cette explication brève et précise.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [2012] TRIGGER sur UPDATE INSERT de plusieurs champs
    Par SEGA team dans le forum Développement
    Réponses: 8
    Dernier message: 10/06/2015, 17h43
  2. Trigger sur table en INSERT
    Par salsamania dans le forum Développement
    Réponses: 7
    Dernier message: 28/09/2010, 16h27
  3. trigger sur update
    Par tofito dans le forum Débuter
    Réponses: 2
    Dernier message: 07/12/2009, 14h08
  4. Trigger sur update d'un champ
    Par Fused dans le forum Développement
    Réponses: 3
    Dernier message: 05/08/2009, 19h45
  5. Problème lors d'un trigger sur update
    Par yonialhadeff dans le forum Développement
    Réponses: 1
    Dernier message: 09/10/2007, 08h44

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo