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

 PostgreSQL Discussion :

ERROR: record "new" is not assigned yet


Sujet :

PostgreSQL

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    193
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 193
    Points : 53
    Points
    53
    Par défaut ERROR: record "new" is not assigned yet
    Bonjour,

    Je cherche à inserer dans la table acteur un nupplet
    Mais je reçois un message d'erreur:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ERROR:  record "new" is not assigned yet
    DETAIL:  The tuple structure of a not-yet-assigned record is indeterminate.
    CONTEXT:  PL/pgSQL function "functiontriggerinsertionacteur" line 2 at IF
    Voici mon code:

    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
    CREATE OR REPLACE FUNCTION b.functionTriggerinsertionacteur()
    returns TRIGGER AS 
    '
    BEGIN
    IF(NEW.ArtistID, NEW.nom, NEW.nationalite) IN
    (Select ArtistID,nom,nationalite From b.artiste) 
    Then Insert Into b.acteur Values (NEW.ArtistID, NEW.Nom, NEW.nationalite);
    END IF;
    RETURN NEW;
    END;
    '
    LANGUAGE 'plpgsql';
     
     
    CREATE TRIGGER INSERTIONACTEUR
    BEFORE INSERT ON b.Acteur
    FOR each statement
    execute procedure b.functionTriggerinsertionacteur()
    Pouvez vous m'aider svp? Merci

  2. #2
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2008
    Messages
    1 874
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Octobre 2008
    Messages : 1 874
    Points : 2 890
    Points
    2 890
    Par défaut
    A mon sens ce n'est pas un trigger FOR EACH STATEMENT qu'il faut employer ici, mais FOR EACH ROW.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    193
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 193
    Points : 53
    Points
    53
    Par défaut
    Merci de m'aider: il s'agit de mon premier trigger (et j'en ai vu qu'un seul en cours()

    OK maintenant le code est devenu:

    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 OR REPLACE FUNCTION functionTriggerinsertionacteur()
    returns TRIGGER AS 
    '
    BEGIN
    if New.artistID not in (Select artistID From artiste)
    THEN RAISE EXCEPTION ''lacteur nest pas present dabs artiste '';
    ELSE if (NEW.nom, NEW.nationalite) not in (Select nom, nationalite From artiste) 
    THEN RAISE EXCEPTION '' artist_id deja utilise''; 
    ELSE
    INSERT INTO acteur VALUES (NEW.ArtistID, NEW.Nom, NEW.nationalite);
    END IF;
    END IF;
    END;'
    LANGUAGE 'plpgsql';
     
    CREATE TRIGGER INSERTIONACTEUR
    BEFORE INSERT ON Acteur
    FOR each row
    execute procedure functionTriggerinsertionacteur();
    Maintenant j'ai ce problème

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    ERROR:  stack depth limit exceeded
    HINT:  Increase the configuration parameter "max_stack_depth", after ensuring the platform's stack depth limit is adequate.
    CONTEXT:  SQL statement "SELECT   $1  not in (Select artistID From artiste)"
    PL/pgSQL function "functiontriggerinsertionacteur" line 2 at IF
    SQL statement "INSERT INTO acteur VALUES ( $1 ,  $2 ,  $3 )"
    PL/pgSQL function "functiontriggerinsertionacteur" line 7 at SQL statement
    SQL statement "INSERT INTO acteur VALUES ( $1 ,  $2 ,  $3 )"
    PL/pgSQL function "functiontriggerinsertionacteur" line 7 at SQL statement
    SQL statement "INSERT INTO acteur VALUES ( $1 ,  $2 ,  $3 )"
    PL/pgSQL function "functiontriggerinsertionacteur" line 7 at SQL statement
    SQL statement "INSERT INTO acteur VALUES ( $1 ,  $2 ,  $3 )"

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    193
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 193
    Points : 53
    Points
    53
    Par défaut
    non c'est bon merci!!!!!!!!!!!!!!

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

Discussions similaires

  1. ERROR: record "new" is not assigned yet
    Par voxov dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 08/09/2010, 15h23
  2. Réponses: 6
    Dernier message: 21/10/2005, 18h59
  3. probleme avec : record "new" is not assigned yet D
    Par chtieu dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 31/03/2005, 20h44

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