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 permettant d'insérer une ligne dans une table [2005]


Sujet :

Développement SQL Server

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2013
    Messages : 7
    Points : 7
    Points
    7
    Par défaut Trigger permettant d'insérer une ligne dans une table
    Bonjour,

    Lors de l'insertion d'une ligne dans une table, j'aimerai en quelque sorte dupliquer cette ligne dans cette même table, je m'explique:
    Si la ligne insérée à une certaine valeur dans une colonne, je dois dupliquer cette ligne en indiquant une autre valeur dans cette colonne de la ligne dupliquée.

    J'ai entamé un petit bout de code d'essai mais je bute sur qq problèmes:

    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
    CREATE TRIGGER [dbo].[AFTER_INSERT_DUPLICATE_CCH] ON [dbo].[COMCLIHEACCH] 
       AFTER INSERT
    AS 
    BEGIN
    	-- SET NOCOUNT ON added to prevent extra result sets from
    	-- interfering with SELECT statements.
    	SET NOCOUNT ON;
     
        -- Insert statements for trigger here
    	if (select refsocch from inserted) in ('AG','CH')
    	begin
    		insert into [dbo].[COMCLIHEACCH]
    		(CLEUNICCH,CREUTICCH,CREDATCCH,CREHEUCCH,MAJUTICCH,MAJDATCCH,MAJHEUCCH,REFSOCCCH,NUMCMDCCH,NUMCLICCH,CODCOMCCH,CODPAYCCH)
    		values
    		(inserted.CLEUNICCH,inserted.CREUTICCH,inserted.CREDATCCH,inserted.CREHEUCCH,inserted.MAJUTICCH,inserted.MAJDATCCH,
    		inserted.MAJHEUCCH,'CA',inserted.NUMCMDCCH,inserted.NUMCLICCH,inserted.CODCOMCCH,inserted.CODPAYCCH)
    	end
    END
    GO
    Je constate que dans mon test ci-dessus je ne peux pas utiliser inserted.nomdemacolonne (The name "inserted.CLEUNICCH" is not permitted in this context. Valid expressions are constants, constant expressions, and (in some contexts) variables. Column names are not permitted.)
    Vu que la ligne compte une grande quantité de colonnes (il n'y en a qu'une partie ci-dessus), j'aimerai une solution simple pour récupérer (avant insertion) toutes les valeurs de la ligne inserted et ne modifier que les 2 ou 3 colonnes nécessaires, ce n'est pas ce que j'ai tenté dans mon exemple car je ne sais pas comment m'y prendre.

    Merci d'avance si vous avez une piste ou un post qui traite déjà de ce sujet...


  2. #2
    Invité
    Invité(e)
    Par défaut
    Votre déclencheur n'est pas ensembliste.
    Que se passe-t-il quand inserted contient plusieurs lignes pour ça :
    IF (SELECT refsocch FROM inserted) IN ('AG','CH')

    Essayez-ça. Je l'ai fait rapidement et je n'ai pas testé mais l'idée est là.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE TRIGGER [dbo].[AFTER_INSERT_DUPLICATE_CCH] ON [dbo].[COMCLIHEACCH] 
       AFTER INSERT
    AS 
    BEGIN
    INSERT INTO [dbo].[COMCLIHEACCH]
    	(CLEUNICCH,CREUTICCH,CREDATCCH,CREHEUCCH,MAJUTICCH,MAJDATCCH,MAJHEUCCH,REFSOCCCH,NUMCMDCCH,NUMCLICCH,CODCOMCCH,CODPAYCCH)
    SELECT 
    CLEUNICCH,CREUTICCH,CREDATCCH,CREHEUCCH,MAJUTICCH,MAJDATCCH,
    MAJHEUCCH,'CA',NUMCMDCCH,NUMCLICCH,CODCOMCCH,CODPAYCCH
    from INSERTED
    where refsocch IN ('AG','CH')
     
    END
    GO

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Inscrit en
    Juillet 2013
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2013
    Messages : 7
    Points : 7
    Points
    7
    Par défaut
    Merci beaucoup, ça fonctionne.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 15/10/2009, 13h33
  2. [XL-2003] Insérer la valeur d'une cellule dans une phrase d'une autre
    Par DonaldTron dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 05/04/2009, 19h50
  3. [E-00] Syntaxe pour insérer une ligne ou une colonne dans une feuille
    Par Benjycool dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 02/02/2009, 09h27
  4. [MySQL] Comment insérer 6 lignes en une fois dans une base mysql avec du PHP ?
    Par Alexandrebox dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 10/02/2008, 14h39
  5. Réponses: 3
    Dernier message: 29/01/2008, 12h08

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