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

Requêtes PostgreSQL Discussion :

creation fonction sql


Sujet :

Requêtes PostgreSQL

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    264
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 264
    Points : 104
    Points
    104
    Par défaut creation fonction sql
    Bonsoir, étant un peu novice dans la création de fonction sql, je commence par m'entraîner un peu.

    je crée une fonction :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    	create or replace function tuples(text) returns integer as '
     
    	DECLARE 
    		nbtuple INTEGER;
     
    	begin
     
    		execute ''Select count(*) from'' || $1 into nb_tuple ;
    		returns nb_tuple ;
    	end ;
     
    	' language sql ;
    Alors je veux avoir le nombre de tupe dans un champs que j'aurai transmis en paramétre.
    le probléme est que j'ai une erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    psql:test.sql:11: ERREUR:  erreur de syntaxe sur ou près de « integer »
    LINE 4:   nocli integer;
                    ^
    Pourtant j'ai bien vu un peu partout les diffrentes syntaxe, normalement j'ai pas d'erreur, alors que mon compilateur me dit que si ...Je suis sous postgresql 8.3.

    Alors est ce que qqun aurrait une idée ?

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    264
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 264
    Points : 104
    Points
    104
    Par défaut
    Je reformule mon problème : J'ai un souci dans la déclaration des variables. Faut-il utiliser une syntaxe particulière ?
    Je crois que j'ai un souci d'encapsulation des données...
    Mais je ne vois pas à quelle niveau !

  3. #3
    Membre éclairé
    Homme Profil pro
    Inscrit en
    Janvier 2006
    Messages
    476
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corse (Corse)

    Informations forums :
    Inscription : Janvier 2006
    Messages : 476
    Points : 831
    Points
    831
    Par défaut
    bonsoir , tout d'abord il faut utiliser le langage pgsql
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    CREATE OR REPLACE FUNCTION tuples(text) returns integer AS $BODY$
     
     
    	DECLARE 
    		nbtuple INTEGER;
     
    	BEGIN
     
    		execute 'Select count(*) from ' || quote_ident($1) into nb_tuple ;
    		return nb_tuple ;
    	END;
     $BODY$
     
    	 LANGUAGE 'plpgsql' ;

  4. #4
    Membre régulier
    Profil pro
    Inscrit en
    Septembre 2006
    Messages
    264
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2006
    Messages : 264
    Points : 104
    Points
    104
    Par défaut
    C'est bon sa à marché .....

    Je ne savais pas ce que c'était que le plpgsql .... j'ai du crée ce lanage par un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Create language plpgsql
    Merci @++

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

Discussions similaires

  1. creation d'une fonction SQL pour generer du XML
    Par MuldyMath dans le forum Oracle
    Réponses: 3
    Dernier message: 07/06/2006, 11h22
  2. Syntaxe de la fonction SQL month() ??
    Par merlubreizh dans le forum Langage SQL
    Réponses: 3
    Dernier message: 01/09/2005, 11h16
  3. probleme avec creation requete sql server
    Par Firas_tn dans le forum MS SQL Server
    Réponses: 19
    Dernier message: 15/04/2005, 12h12
  4. [Fonction SQL Serveur] convertir des secondes en heure
    Par falcon dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 17/11/2004, 17h22
  5. fonction sql "LIMIT" en interbase?
    Par GMI dans le forum InterBase
    Réponses: 6
    Dernier message: 20/09/2004, 14h04

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