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

PL/SQL Oracle Discussion :

Fonction pluviométrie PL/SQL


Sujet :

PL/SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Juin 2012
    Messages
    64
    Détails du profil
    Informations forums :
    Inscription : Juin 2012
    Messages : 64
    Par défaut Fonction pluviométrie PL/SQL
    Bonjour,

    J'ai testé avec SQL Command de APEX 3.1 ces commandes, qui me permettent d'obtenir pour la date de la veille la pluviométrie en interrogeant une table adéquate.

    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
    WITH RAINFALL AS
    (
    	SELECT  DATE1	RAINFALLDATE,
        		VALEUR	VALUE
      	FROM	EVV_STPL
      	WHERE	CLEF_VAR	= 4723
      	AND	TO_DATE(DATE1, 'DD/MM/YYYY') = TO_DATE(sysdate-1, 'DD/MM/YYYY')
      )
     
    	SELECT	  SUM (TOTO) 		CUMUL
      	FROM      (
    		    SELECT  TRUNC (RAINFALLDATE)	AS datte,
          		    	    VALUE,
          			    LEAD (VALUE) OVER ( PARTITION BY  TRUNC (RAINFALLDATE) 
    			    	 	      	ORDER BY      RAINFALLDATE
    					      ) - VALUE		AS TOTO
        		    FROM    RAINFALL
        		  )
      	WHERE 	  TOTO	>= 0
      	GROUP BY  datte
    J'obtiens bien ce que je veux, mais maintenant je veux transformer cela en fonction.

    Donc j'ai créé cette fonction :

    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
    22
    23
    24
    25
    26
    27
    28
    29
    create or replace function "CALC_PLUVIO" (clef_var in NUMBER)
    return number
    is
    stmt number;
     
    BEGIN
     
    SELECT	  SUM (TOTO)  	INTO	CUMUL
      	FROM      (
    		    SELECT  TRUNC (RAINFALLDATE)	AS datte,
          		    	    VALUE,
          			    LEAD (VALUE) OVER ( PARTITION BY  TRUNC (RAINFALLDATE) 
    			    	 	      	ORDER BY      RAINFALLDATE
    					      ) - VALUE		AS TOTO
        		    FROM    RAINFALL
        		  )
      	WHERE 	  TOTO	>= 0
      	GROUP BY  datte
     
    WITH RAINFALL AS
    (
    	SELECT  DATE1	RAINFALLDATE,
        		VALEUR	VALUE
      	FROM	EVV_STPL
      	WHERE	CLEF_VAR	= clef_var
      	AND	TO_DATE(DATE1) = TO_DATE(sysdate-1)
      );
    RETURN CUMUL;
    END;
    et là ça ne fonctionne plus, :
    Compilation failed,line 18 (10:55:34)
    PL/SQL: ORA-00933: la commande SQL ne se termine pas correctementCompilation failed,line 7 (10:55:34)
    PL/SQL: SQL Statement ignored
    Je ne dois pas être très loin de la solution, que je ne vois pas.

  2. #2
    Membre Expert
    Homme Profil pro
    Chef de projet MOA
    Inscrit en
    Février 2012
    Messages
    652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : Chef de projet MOA
    Secteur : Distribution

    Informations forums :
    Inscription : Février 2012
    Messages : 652
    Par défaut
    Tape "sho err" pour voir les erreurs
    Ensuite on pourra avaner un peu plus loin

    EDIT : oups un peu tard...

Discussions similaires

  1. [SQL] fonction d'insertion sql
    Par wdionysos dans le forum PHP & Base de données
    Réponses: 11
    Dernier message: 03/04/2006, 16h32
  2. Quel SGBD permet d'écrire ses fonctions d'agrégation SQL?
    Par Machin0410 dans le forum Décisions SGBD
    Réponses: 1
    Dernier message: 28/03/2006, 17h31
  3. Réponses: 4
    Dernier message: 18/01/2006, 10h33
  4. Fonction "Format" sous SQL
    Par Fabby69 dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 08/10/2004, 09h07
  5. fonction left avec sql server 6.5
    Par shake dans le forum Langage SQL
    Réponses: 2
    Dernier message: 29/06/2004, 08h48

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