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

SQL Oracle Discussion :

Appeler une fonction dans un package depuis SQL


Sujet :

SQL Oracle

  1. #1
    Membre expérimenté

    Profil pro
    Inscrit en
    Avril 2008
    Messages
    1 143
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 1 143
    Points : 1 353
    Points
    1 353
    Par défaut Appeler une fonction dans un package depuis SQL
    Bonjour,

    Voici ce que je souhaite faire.

    Recuperer des valeurs dans une vue Oracle ( ça je sais faire ) , ensuite passer 3 champs en param à ma fonction Oracle ( déjà faite ) et retourner ces 3 champs plus une colonne supplémentaire qui va stocker la réponse de chaque appel de ma fonction.

    Comment faire?

    Je dois faire ceci via SQL JDBC , est-ce faisable?

    Sinon je dois faire quoi, une proc stoc en PL/SQL?

    Un exemple de syntaxe serait super sympa, je me fait vieux en PL/SQL

    Merci,

  2. #2
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Exemples d'appels de fonctions d'un package PL/SQL:http://sheikyerbouti.developpez.com/...age=Chap4#L4.3

    Pour appeler dans un ordre SQL la fonction f du package p

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select p.f(<paramètres>) from ...;

  3. #3
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Il y a mieux qu’appeler des fonctions en SQL. Utilisez les fonctions pipeline, comme dans l’exemple
    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
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
     
    Connected to Oracle9i Enterprise Edition Release 9.2.0.7.0 
    Connected as mni
     
    SQL> 
    SQL> CREATE OR REPLACE TYPE EMP1_OT AS OBJECT
      2  ( empno      NUMBER(4),
      3    ename      VARCHAR2(10),
      4    sal        NUMBER(7,2),
      5    up_ename  VARCHAR2(10)
      6  )
      7  /
     
    Type created
    SQL> CREATE OR REPLACE TYPE EMP1_NTT AS TABLE OF emp1_ot
      2  /
     
    Type created
    SQL> create or replace function emp_tranforme (p_deptno In dept.deptno%Type)
      2  return EMP1_NTT pipelined Is
      3  Begin
      4    For crs In (Select e.empno, e.ename, e.sal
      5                  from emp e
      6                 Where e.deptno = p_deptno
      7               )
      8    Loop
      9      pipe row(emp1_ot(crs.empno, crs.ename, crs.sal, Initcap(crs.ename)));
     10    End Loop;
     11    Return;
     12  End;
     13  /
     
    Function created
    SQL> Select * from table(emp_tranforme(10))
      2  /
     
         EMPNO ENAME             SAL UP_ENAME
    ---------- ---------- ---------- ----------
          7782 CLARK            2450 Clark
          7839 KING             5000 King
          7934 MILLER           1300 Miller
     
    SQL>

Discussions similaires

  1. Réponses: 8
    Dernier message: 05/07/2011, 11h51
  2. Réponses: 0
    Dernier message: 27/04/2009, 16h13
  3. Appeler une fonction dans le body
    Par FredKéKé dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 05/04/2006, 10h43
  4. Appeler une fonction dans un autre cadre !
    Par rich25200 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 01/11/2005, 13h01
  5. Réponses: 7
    Dernier message: 10/09/2005, 16h49

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