Précédent   Forum des professionnels en informatique > Bases de données > MS SQL-Server > Développement
Développement Forum d'entraide sur le Transact-SQL, le CLR, les procédures stockées, les triggers, les requêtes SQL
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 12/04/2011, 15h46   #1
Nouveau Membre du Club
 
Homme Maxime
Développeur Web et Mobile
Inscription : juin 2010
Messages : 68
Détails du profil
Informations personnelles :
Nom : Homme Maxime
Âge : 21
Localisation : France, Gard (Languedoc Roussillon)

Informations professionnelles :
Activité : Développeur Web et Mobile

Informations forums :
Inscription : juin 2010
Messages : 68
Points : 34
Points : 34
Envoyer un message via MSN à Xenonmax
Par défaut Triggers Insert lors d'un Insert

Bonjour,

Je dois faire avec un trigger un insert dans la base DESTINATIONS lorsque je fais un insert dans la base DEPARTS.

Alors j'ai fait le trigger ci dessous :
Code :
1
2
3
4
5
6
7
8
9
10
 
ALTER TRIGGER [dbo].[TR_AjoutDestination] 
   ON  [dbo].[DEPARTS] 
   AFTER INSERT
AS 
BEGIN
	INSERT INTO dbo.DESTINATIONS
	SELECT DEPARTS_ID, DEPARTS_LIBELLE, DEPARTS_VILLE, DEPARTS_CP
	FROM new
END
Lorsque je fait un ajout dans DEPART il me met ce message d'erreur :
No row was updated.
The data in row 1 was not committed.
Erreor Source: .NetSqlClient Data Provider.
Erreor Message: Invalid object name 'new'.


Donc voilà, je commence à utiliser SQL Server pour mes études en BTS IG.

Je vous remercie d'avance pour vos réponses.
Xenonmax est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/04/2011, 17h32   #2
Membre Expert
 
Inscription : janvier 2010
Messages : 1 084
Détails du profil
Informations personnelles :
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : janvier 2010
Messages : 1 084
Points : 1 573
Points : 1 573
Bonjour

Vous devez utiliser la pseudo table "INSERTED" qui contient les données insérées dans la table sur laquelle porte le trigger

Je suppose que DEPARTS_ID, DEPARTS_LIBELLE, DEPARTS_VILLE, DEPARTS_CP sont des colonnes de la table DEPARTS

Faites
Code SQL :
1
2
3
4
5
6
7
8
9
10
 
ALTER TRIGGER [dbo].[TR_AjoutDestination] 
   ON  [dbo].[DEPARTS] 
   AFTER INSERT
AS 
BEGIN
	INSERT INTO dbo.DESTINATIONS
	SELECT DEPARTS_ID, DEPARTS_LIBELLE, DEPARTS_VILLE, DEPARTS_CP
	FROM INSERTED
END
aieeeuuuuu est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 12/04/2011, 18h41   #3
Nouveau Membre du Club
 
Homme Maxime
Développeur Web et Mobile
Inscription : juin 2010
Messages : 68
Détails du profil
Informations personnelles :
Nom : Homme Maxime
Âge : 21
Localisation : France, Gard (Languedoc Roussillon)

Informations professionnelles :
Activité : Développeur Web et Mobile

Informations forums :
Inscription : juin 2010
Messages : 68
Points : 34
Points : 34
Envoyer un message via MSN à Xenonmax
Merci beaucoup, c'était bien çà.
J'ai des cours mais c'est vachement mal expliqué... -_-"
Xenonmax est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 02h57.


 
 
 
 
Partenaires

Hébergement Web