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 :

[ PL/pgSQL ] Passage de paramètres et nom de table


Sujet :

PostgreSQL

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2004
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 19
    Points : 19
    Points
    19
    Par défaut [ PL/pgSQL ] Passage de paramètres et nom de table
    Bonjour à tous,

    J'ai une petite question à vous poser :
    Si, je crée une fonction prenant comme paramètre une variable de type "text", est ce que je peux utiliser cette variable comme nom de table pour mes select ?

    Par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    create function foo(text) returns integer as '
    declare
    	tablename alias for $1;
    begin	
    select into resId id from tablename where ...;
     
    (...)
    Pour l'instant ça marche pas des masses chez moi, ya t-il une 'bonne' méthode pour y arriver ?

  2. #2
    Membre habitué Avatar de champijulie
    Inscrit en
    Mai 2005
    Messages
    147
    Détails du profil
    Informations forums :
    Inscription : Mai 2005
    Messages : 147
    Points : 131
    Points
    131
    Par défaut
    Je pense que ça doit marcher. En tous cas, quand tu déclares la fonction, ça compile.

    Voilà.
    @+
    champpijulie

  3. #3
    Membre habitué
    Inscrit en
    Mai 2002
    Messages
    131
    Détails du profil
    Informations forums :
    Inscription : Mai 2002
    Messages : 131
    Points : 150
    Points
    150
    Par défaut
    Pour créer des requêtes dynamiquement, il faut utiliser la commande EXECUTE

  4. #4
    Membre à l'essai
    Inscrit en
    Avril 2004
    Messages
    19
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 19
    Points : 19
    Points
    19
    Par défaut
    Merci bien

    Jdonne la réponse pour ceux qui auraient le même problème avec la flemme de chercher :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    create function foo(text) returns integer as '
    declare
    tablename alias for $1;
    rec RECORD;
    begin   
     
    FOR rec IN EXECUTE('select id from' || tablename || ' where ..) LOOP
    resId := rec.id;
    END LOOP;
     
    (...)

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

Discussions similaires

  1. [Script SQL] Passage comme paramètre du nom de la base de données
    Par kha_yassine dans le forum SQL Procédural
    Réponses: 1
    Dernier message: 08/11/2013, 17h45
  2. [2008] Utiliser un paramètre comme nom de table SQL
    Par jbrusselle dans le forum SSRS
    Réponses: 2
    Dernier message: 29/08/2012, 18h03
  3. paramètre comme nom de table dans la commande alter table
    Par zebrette dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 10/11/2010, 16h50
  4. Passage de paramètres entre dataset et table
    Par satmbal dans le forum BIRT
    Réponses: 8
    Dernier message: 06/06/2008, 15h12
  5. Réponses: 3
    Dernier message: 23/03/2005, 11h28

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