Précédent   Forum des professionnels en informatique > Bases de données > PostgreSQL > Requêtes
Requêtes Forum d'entraide sur les requêtes SQL spécifiques à PostgreSQL, les triggers, les vues, etc.
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 25/01/2012, 15h39   #1
Invité régulier
 
Inscription : novembre 2007
Messages : 27
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 27
Points : 7
Points : 7
Par défaut Trigger : Insertions multiples

Bonjour,

J'ai une requête d'ajout qui fonctionne bien si je la lance dans un fichier sql

Code :
1
2
INSERT INTO  sdea_intranet (link) 
       SELECT docpath||'###'||docname||'###'||destination  FROM v_csdocs_sys WHERE d_dkey =NEW.d_dkey;

Par contre, dans mon trigger, rien ne se passe :

Code :
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
32
33
34
-- Function: setdateintranet()
 
-- DROP FUNCTION setdateintranet();
 
CREATE OR REPLACE FUNCTION setdateintranet()
  RETURNS "trigger" AS
$BODY$
DECLARE
	new_id integer;
	new_link varchar; 
 
 
BEGIN 
      IF NEW.flag_publication_intranet = 'OUI'   THEN	 
	 NEW.d_date_publi_intranet := now();
 
        INSERT INTO  sdea_intranet (link) 
        SELECT docpath||'###'||docname||'###'||destination  FROM v_csdocs_sys WHERE d_dkey =NEW.d_dkey;
 
 
      ELSE
        NEW.d_date_publi_intranet := NULL;
        -- on enlève la ligne dans la table
 
      END IF;
 
      RETURN NEW;
 
END;
$BODY$
  LANGUAGE plpgsql VOLATILE;
ALTER FUNCTION setdateintranet() OWNER TO sdea;
GRANT EXECUTE ON FUNCTION setdateintranet() TO public;
GRANT EXECUTE ON FUNCTION setdateintranet() TO sdea;

Merci de votre aide.
Mescaline est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 15h49   #2
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 669
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 669
Points : 2 680
Points : 2 680
Bonjour,

Quel est le code de liaison entre ce trigger et votre ... table / vue ?

Ensuite qu'est censé faire ce trigger ?
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 16h35   #3
Invité régulier
 
Inscription : novembre 2007
Messages : 27
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 27
Points : 7
Points : 7
Bonjour,

Voici le code trigger qui est sur la table,

Code :
1
2
3
4
5
CREATE TRIGGER "trgSetDatePubliIntra"
  BEFORE INSERT OR UPDATE
  ON sdea_document
  FOR EACH ROW
  EXECUTE PROCEDURE setdateintranet();
Le but de ce trigger est qu'à chaque évènement, je lance une requête sur une vue qui me retourne une ou plusieurs lignes selon la clef Ces lignes doivent ensuite être ajoutées ou supprimées (si existantes) dans une autre table.

Ma requête d'ajout fonctionne bien, hors mis intégrée dans le bloc IF de la fonction trigger setdateintranet().

Merci à vous,
Mescaline est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 16h47   #4
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 669
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 669
Points : 2 680
Points : 2 680
Oki et quel est votre requete d'insert / update sur la table sdea_document ?
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 16h58   #5
Invité régulier
 
Inscription : novembre 2007
Messages : 27
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 27
Points : 7
Points : 7
Code :
UPDATE sdea_document SET flag_publication_intranet='NON' WHERE d_dkey=102285;
Voici une requête sur ma table général, là doit se déclencher le trigger, qui selon une condition lance la requête d'ajout dans l'autre table
Code :
1
2
 INSERT INTO sdea_intranet (link) 
 SELECT docpath||'###'||docname||'###'||destination  FROM v_csdocs_sys WHERE d_dkey = 102285 ;
J'ai fait un essai, la requête d'ajout fonctionne bien, si je lui envoie qu'une seule ligne, par contre dans cet exemple ci j'ai 3 lignes qui sont retournées par la requête
Code :
  SELECT docpath||'###'||docname||'###'||destination  FROM v_csdocs_sys WHERE d_dkey = 102285 ;
Le nombre de ligne ne devrait pas influencer l' Insert, non ?

Merci encore...
Mescaline est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 17h01   #6
Invité régulier
 
Inscription : novembre 2007
Messages : 27
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 27
Points : 7
Points : 7
J'ai mis ma requête dans une fonction test en lui passant pour argument un champ, elle m'ajoute bien toute mes lignes dans la seconde table....
A suivre demain...merci encore pour votre aide !
Mescaline est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 17h02   #7
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 669
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 669
Points : 2 680
Points : 2 680
votre condition c'est flag_publication_intranet='OUI' pour faire l'insert.

Donc si aucun insert n'est fait dans le cas que vous nous présentez c'est normal.
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 25/01/2012, 19h24   #8
Invité régulier
 
Inscription : novembre 2007
Messages : 27
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 27
Points : 7
Points : 7
Re,

J'ai copié la mauvaise requête, je faisais des essais sur mon exemple...
Mescaline est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/01/2012, 09h12   #9
Expert Confirmé
 
Homme
Inscription : mai 2002
Messages : 1 669
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 29
Localisation : France, Rhône (Rhône Alpes)

Informations forums :
Inscription : mai 2002
Messages : 1 669
Points : 2 680
Points : 2 680
Citation:
Envoyé par Mescaline Voir le message
J'ai fait un essai, la requête d'ajout fonctionne bien, si je lui envoie qu'une seule ligne, par contre dans cet exemple ci j'ai 3 lignes qui sont retournées par la requête
Code :
  SELECT docpath||'###'||docname||'###'||destination  FROM v_csdocs_sys WHERE d_dkey = 102285 ;
Le nombre de ligne ne devrait pas influencer l' Insert, non ?
Il devrai insérer 3 lignes dans ce cas là.
punkoff est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/01/2012, 11h46   #10
Invité régulier
 
Inscription : novembre 2007
Messages : 27
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 27
Points : 7
Points : 7
J'ai refais une table de destination avec un seul champ, sans contrainte, sans clef primaire...

Sur ma table source j'ai donc :

Code :
1
2
3
4
5
CREATE TRIGGER "trgAddListe"
  AFTER INSERT OR UPDATE
  ON sdea_document
  FOR EACH ROW
  EXECUTE PROCEDURE add_liste();
La fonction add_liste()

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
-- Function: add_liste()
 
-- DROP FUNCTION add_liste();
 
CREATE OR REPLACE FUNCTION add_liste()
  RETURNS "trigger" AS
$BODY$   
BEGIN  
 
     INSERT INTO  sdea_export_docs (link) 
	SELECT docpath||'###'||docname||'###'||destination  FROM v_csdocs_sys WHERE d_dkey =NEW.d_dkey;
     RETURN NEW;
 
END;
$BODY$
  LANGUAGE plpgsql VOLATILE;
ALTER FUNCTION add_liste() OWNER TO sdea;
GRANT EXECUTE ON FUNCTION add_liste() TO public;
GRANT EXECUTE ON FUNCTION add_liste() TO sdea;
Et mes lignes sont bien toutes copiées dans la nouvelle table, par contre, je ne comprend pas ce qui n'allait pas avant ?
Mescaline est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/01/2012, 13h07   #11
Membre chevronné
 
Avatar de alassanediakite
 
Homme Alassane Diakité
Conseil - Consultant en systèmes d'information
Inscription : août 2006
Messages : 539
Détails du profil
Informations personnelles :
Nom : Homme Alassane Diakité
Âge : 34
Localisation : Mali

Informations professionnelles :
Activité : Conseil - Consultant en systèmes d'information

Informations forums :
Inscription : août 2006
Messages : 539
Points : 604
Points : 604
Envoyer un message via Yahoo à alassanediakite
Salut
Parole de débutant
Si le test 'OUI' échoue avec "flag_publication_intranet = 'OUI'" peut être qu'il contient du NULL ou (si c'est de type boolean) il faut voir du coté de YES.
__________________
Le monde est trop bien programmé pour être l’œuvre du hasard…
alassanediakite est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/01/2012, 14h48   #12
Invité régulier
 
Inscription : novembre 2007
Messages : 27
Détails du profil
Informations forums :
Inscription : novembre 2007
Messages : 27
Points : 7
Points : 7
Depuis mon dernier post mes essais sont concluants.
Ma requête fonctionne bien, depuis le départ il s'agissait surement du manque de la ligne RETURN NEW; qu'il y a après l'insert.
Mescaline 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 00h42.


 
 
 
 
Partenaires

Hébergement Web