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

MS SQL Server Discussion :

Trigger update avec sql server 2005


Sujet :

MS SQL Server

  1. #1
    Membre éclairé
    Inscrit en
    Septembre 2007
    Messages
    1 137
    Détails du profil
    Informations personnelles :
    Âge : 41

    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 137
    Points : 707
    Points
    707
    Par défaut Trigger update avec sql server 2005
    Bonjour, ci joint un trigger qui s'execute sur un update d'une table.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
     
    ALTER TRIGGER UpdateLOSSDET
    ON dbo.LOSSDET
    AFTER UPDATE
    AS
    BEGIN
    DECLARE @oldName VARCHAR(25), @newName VARCHAR(25),
    		@lossid VARCHAR(15), @typeperteid varchar(10)
     
    SELECT @lossid = (SELECT LossID FROM deleted)
    SELECT @oldName = (SELECT Redacteur FROM deleted)
    SELECT @newName = (SELECT Redacteur FROM inserted)
    SELECT @typeperteid = (SELECT TypePerteID FROM inserted)
     
    IF (@typeperteid = 12)
    BEGIN
    	IF (@oldName != @newName)
    		BEGIN
    			UPDATE DROITS_PDAC SET UserID = @newName
    			WHERE DROITS_PDAC.LossID = @lossid AND DROITS_PDAC.LeNiveau = 5
    		END;
    	else
    		BEGIN
    			RETURN
    		END
    END;
    else
    BEGIN
    	RETURN
    END;
    END
    le pb est lors de l'affectation de mes variables, par ex select Redacteur FROM inserted pour ramener plusieur enregistrement, je voudrais savoir comment je peux faire pour qu'il prenne en compte s'il y a plusieurs ligne du fichier à modifier en meme temps.
    Merci

  2. #2
    Modérateur

    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Janvier 2005
    Messages
    5 826
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2005
    Messages : 5 826
    Points : 12 371
    Points
    12 371
    Par défaut
    Bonjour,

    Le traitement que vous avez écrit pour votre trigger n'est pas ensembliste, ce qui induit votre problème.
    Vous pouvez corriger avec ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    ALTER TRIGGER UpdateLOSSDET
    	ON dbo.LOSSDET
    AFTER UPDATE
    AS
    BEGIN
    	UPDATE dbo.DROITS_PDAC
    	SET UserID = I.Redacteur
    	FROM dbo.DROITS_PDAC D
    	JOIN INSERTED I ON I.LossID = D.LossID
    	WHERE I.Redacteur <> D.Redacteur
    	AND I.TypePerteID = 12
    	AND D.LeNiveau = 5
    END
    De manière générale, il est avantageux à de nombreux niveau de préférer du code ensembliste à du code itératif.
    Les bases de données sont conçues pour traiter des ensembles de données, pas pour faire du ligne à ligne (ce n'est pas le cas pour les triggers sous Oracle par exemple, ou vous devez spécifier explicitement FOR EACH ROW).
    Dès lors rien ne doit vous empêcher d'écrire une jointure sur la table virtuelle INSERTED

    @++

Discussions similaires

  1. Triggers sur insertion avec SQL Server 2005
    Par Naail dans le forum Développement
    Réponses: 14
    Dernier message: 01/07/2009, 15h23
  2. planifier une sauvegarde avec sql server 2005
    Par morados dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 15/06/2006, 14h09
  3. [VS] Remote connection avec SQL Server 2005 Express
    Par L`artiste dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 28/05/2006, 22h28
  4. Cube OLAP local avec SQL Server 2005 ??
    Par atom.hic dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 31/03/2006, 16h27
  5. [SQL-Server] Je n'arrive pas à faire tourner php avec Sql server (2005)
    Par bluecurve dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 01/03/2006, 18h50

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