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 :

Afficher une requête avec une fonction


Sujet :

PostgreSQL

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 2
    Points : 2
    Points
    2
    Par défaut Afficher une requête avec une fonction
    Bonsoir,
    j'aimerais savoir comment faire pour afficher le résultat d'une requête en utilisant une fonction pgsql.

    Par exemple, j'ai une table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    create table personne(
        id_personne integer,
        prenom text,
        nom text,
        primary key(id_personne)
    );
    j'exécute la requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    SELECT prenom,nom FROM personne WHERE id_personne = 1;
    Ca affiche la ligne contenant prenom et nom de cette personne.

    Mais, j'aimerais faire la même chose avec une fonction.
    C'est-à-dire quelque chose du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    create or replace function getIdentite(id_p integer)
    	returns void as $$
    begin
    	select prenom, nom from personne
            where id_personne = id_p;
    end;
    $$ language 'plpgsql';
    Mais j'obtiens l'erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    -- ERREUR:  la requête n'a pas de destination pour les données résultantes
    Avez-vous une idée ?
    Merci.

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Septembre 2006
    Messages
    2 937
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Septembre 2006
    Messages : 2 937
    Points : 4 358
    Points
    4 358
    Par défaut
    Dans n'importe quel langage informatique, si vous voulez afficher le résultat d'une fonction, il faut d'abord écrire une fonction et non une procédure :

    il faut retourner un "objet" d'un type reconnu par le langage et non "rien" : "void" en l'occurrence.

    En PL/pgSQL, pour retourner des objets structurés ("records") il faut donc déclarer la fonction comme retournant un type structuré (retournant un seul enregistrement) ou un ensemble de record (SET OF …).

    Le type structuré est soit le rowtype d'une table ou d'une vue soit un type créé pour la circonstance.

  3. #3
    Expert éminent Avatar de kain_tn
    Homme Profil pro
    Inscrit en
    Mars 2005
    Messages
    1 564
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations forums :
    Inscription : Mars 2005
    Messages : 1 564
    Points : 7 289
    Points
    7 289
    Par défaut
    Tu peux également utiliser le mot clé "OUT" pour déclarer des paramètres de sortie et éviter ainsi de définir une nouvelle vue ou d'être lié à une table:

    http://www.postgresql.org/docs/9.1/s...ION-PARAMETERS
    Copier c'est copier; voler c'est vendre un CD une vingtaine d'euros!


    Code C : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    #include <stdio.h>
     
    int main(int argc, char **argv) {
     
        printf("So long, and thanks for the fish, Dennis...\n");
        return 0;
    }

  4. #4
    ced
    ced est déconnecté
    Rédacteur/Modérateur

    Avatar de ced
    Homme Profil pro
    Gestion de bases de données techniques
    Inscrit en
    Avril 2002
    Messages
    6 016
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Gestion de bases de données techniques
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Avril 2002
    Messages : 6 016
    Points : 23 705
    Points
    23 705
    Par défaut
    Bonjour,

    Depuis PostgreSQL 8.4, il est également possible de retourner un type TABLE.
    Voici un exemple tiré de la documentation :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    CREATE FUNCTION extended_sales(p_itemno int) RETURNS TABLE(quantity int, total numeric) AS $$
    BEGIN
        RETURN QUERY SELECT quantity, quantity * price FROM sales WHERE itemno = p_itemno;
    END;
    $$ LANGUAGE plpgsql;
    A adapter à ton propre cas...
    Rédacteur / Modérateur SGBD et R
    Mes tutoriels et la FAQ MySQL

    ----------------------------------------------------
    Pensez aux balises code et au tag
    Une réponse vous a plu ? N'hésitez pas à y mettre un
    Je ne réponds pas aux questions techniques par message privé, les forums sont là pour ça

  5. #5
    Candidat au Club
    Profil pro
    Inscrit en
    Décembre 2011
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2011
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Merci à tous pour vos réponses, j'ai plutôt cherché dans la voie de RECORD et SETOF RECORD, j'ai pu trouver une solution qui est celle-ci :

    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
     
    create or replace function getIdentite(id_p integer)
    	returns setof record as $$
    declare
    	rec record;
    begin
    	for rec in		
    		SELECT prenom, nom 
                    FROM personne
                    WHERE id_personne = id_p;
            loop
    		return next rec;
            end loop;
     
    	return;
    end;
    $$ language 'plpgsql';
    avec l'appel suivant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select * from getIdentite(1) as (prenom text, nom text);
    ce qui devrait afficher quelque chose du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
       prenom   |     nom      
    ------------+--------------
         Alex   |    Térieur

  6. #6
    Membre averti Avatar de mapmip
    Profil pro
    ulla
    Inscrit en
    Juillet 2006
    Messages
    1 315
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : ulla

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 315
    Points : 345
    Points
    345
    Par défaut
    ces reponses sont precieuses je les indexe

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 13/04/2015, 11h17
  2. [XL-2002] Macro de comparaison d'une cellule d'une feuille avec une cellule d'une autre feuille.
    Par steelydan dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 08/09/2010, 12h59
  3. Réponses: 4
    Dernier message: 15/10/2009, 13h33
  4. Afficher le résultat d'une requête avec des côtes
    Par sweet_hell dans le forum Langage SQL
    Réponses: 4
    Dernier message: 27/10/2006, 10h32
  5. #Erreur dans une requête avec une fonction personnalisée
    Par pguiheu dans le forum Requêtes et SQL.
    Réponses: 9
    Dernier message: 04/07/2006, 15h45

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