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 :

missing from_clause entry for table "curr"


Sujet :

PostgreSQL

  1. #1
    Futur Membre du Club
    Inscrit en
    Mars 2007
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 10
    Points : 9
    Points
    9
    Par défaut missing from_clause entry for table "curr"
    Bonjour,
    je veux insérer dans une nouvelle table des champs selectionnés de la table que je donne comme argument à la fonction
    l'erreur généré est la suivante :missing from_clause entry for table "curr"
    le code est :

    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
     
    CREATE OR REPLACE FUNCTION "DM".tkharik("tableName" text)
      RETURNS void AS
    $BODY$DECLARE
    cur refcursor;
    curr record;
    name text;  
    BEGIN
    name:='"'||$1||'"';
    open cur for execute ('select a1, a2 , a3, a4 ,a5 from'||name);
    fetch cur into curr; 
    if  not found then
    exit;
    --nom_fct insère dans une table et j'ai vérifier le bon fonctionnement
    else select "DM"."nom_fct"(curr.a1,curr.a2,curr.a3,curr.a4,curr.a5); 
    end if;  
    close cur;    
    end;   
     
    $BODY$
      LANGUAGE 'plpgsql' VOLATILE;
    merci d'avance de votre aide

  2. #2
    Futur Membre du Club
    Inscrit en
    Mars 2007
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 10
    Points : 9
    Points
    9
    Par défaut
    Citation Envoyé par Dev_ps
    Bonjour,
    je veux insérer dans une nouvelle table des champs selectionnés de la table que je donne comme argument à la fonction
    l'erreur généré est la suivante :missing from_clause entry for table "curr"
    le code est :

    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
     
    CREATE OR REPLACE FUNCTION "DM".tkharik("tableName" text)
      RETURNS void AS
    $BODY$DECLARE
    cur refcursor;
    curr record;
    name text;  
    BEGIN
    name:='"'||$1||'"';
    open cur for execute ('select a1, a2 , a3, a4 ,a5 from'||name);
    fetch cur into curr; 
    if  not found then
    exit;
    --nom_fct insère dans une table et j'ai vérifier le bon fonctionnement
    else select "DM"."nom_fct"(curr.a1,curr.a2,curr.a3,curr.a4,curr.a5); 
    end if;  
    close cur;    
    end;   
     
    $BODY$
      LANGUAGE 'plpgsql' VOLATILE;
    merci d'avance de votre aide

  3. #3
    Futur Membre du Club
    Inscrit en
    Mars 2007
    Messages
    10
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 10
    Points : 9
    Points
    9
    Par défaut
    bon il apparait que l'erreur est dans la nécessité d'utiliser PERFORM lors de l'appel d'une procedure lorsque on est à l'intérieur d'une autre procedure ou fonction.
    parce que PostgreSQL voit une procedure comme étant fonction qui retourne quelque chose de type "nothing", de ce fait il faut spécifier que nous voulons éliminer le résultat de la procedure d'ou PERFORM.

    merci à moi d'avoir répondu à moi

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

Discussions similaires

  1. pg_dump: missing pg_database entry for database "bla bla bla"
    Par djezair31 dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 15/05/2008, 15h31

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