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 :

Select Into EXECUTE IMMEDIATE


Sujet :

PL/SQL Oracle

  1. #1
    Membre du Club
    Profil pro
    Élève
    Inscrit en
    Avril 2004
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Élève

    Informations forums :
    Inscription : Avril 2004
    Messages : 97
    Points : 62
    Points
    62
    Par défaut Select Into EXECUTE IMMEDIATE
    Bonjour,

    Quand dans une proc stock on fait une requête A du type "SELECT... INTO"

    Ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     SELECT ...
        INTO ma_Variable_01
        FROM ...
        WHERE ...
    et, que l'on veut utiliser "ma_Variable_01" dans une requête B.

    Est-on obligé de passer par un EXECUTE IMMEDIATE pour que ça marche ?

    Merci d'avance.

  2. #2
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mai 2012
    Messages
    127
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Mai 2012
    Messages : 127
    Points : 339
    Points
    339
    Par défaut
    Bonjour,

    Non, vous n'êtes absolument pas obligé d'utiliser un EXECUTE IMMEDIATE (qui, en PL/SQL, n'est requis que pour exécuter du SQL dynamique).

  3. #3
    Membre du Club
    Profil pro
    Élève
    Inscrit en
    Avril 2004
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Élève

    Informations forums :
    Inscription : Avril 2004
    Messages : 97
    Points : 62
    Points
    62
    Par défaut
    Ok mais alors comment utiliser ma_Variable_01 quand c'est un nom de table.
    Ex :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select monChamp into monResult from ma_Variable_01;
    Cela ne marche pas, j'ai le message d'erreur "Table ou vue inexistante"

  4. #4
    Membre averti
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Mai 2012
    Messages
    127
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Mai 2012
    Messages : 127
    Points : 339
    Points
    339
    Par défaut
    Bonjour,

    Vous n'aviez pas précisé que la variable était destinée à stocker le nom d'une table. Dans ce cas, c'est du SQL dynamique, ce qui est réalisé soit avec EXECUTE IMMEDIATE, soit avec le package DBMS_SQL

    Dans le cas d'un EXECUTE IMMEDIATE :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    SET SERVEROUTPUT ON
     
    DECLARE
     v_source varchar2(40);
     v_result number;
    BEGIN
      v_source := 'USER_TABLES';
     
      EXECUTE IMMEDIATE 'SELECT count(*) FROM ' || v_source INTO v_result;
      dbms_output.put_line(v_result);
    END;
    /

  5. #5
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 460
    Points : 8 074
    Points
    8 074
    Par défaut
    En effet, si la table est un élément variable, vous devez passer par du SQL dynamique.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    SET SERVEROUTPUT ON
    create or replace procedure compte_table(nom_table VARCHAR2)
    is
        req VARCHAR2(200);
        nb_lignes INTEGER;
    begin
        req:='select count(*) from ' || nom_table;
        execute immediate req into nb_lignes;
        dbms_output.put_line('La table ' || nom_table || ' a ' || nb_lignes || ' lignes');
    end;
    /
    Edit : Désolé du doublon avec la réponse de Baldrick, en plus on a pris le même exemple !
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  6. #6
    Membre du Club
    Profil pro
    Élève
    Inscrit en
    Avril 2004
    Messages
    97
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Élève

    Informations forums :
    Inscription : Avril 2004
    Messages : 97
    Points : 62
    Points
    62
    Par défaut
    Merci beaucoup pour vos réponses !
    Très belle journée à vous.

  7. #7
    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
    Citation Envoyé par Pomalaix Voir le message
    En effet, si la table est un élément variable, vous devez passer par du SQL dynamique.
    ...
    Oui mais non
    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
     
    Connected to Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 
     
    SQL> set serveroutput on
    SQL> 
    SQL> create or replace procedure compte_table(nom_table VARCHAR2)
      2  is
      3      nb_lignes INTEGER;
      4  begin
      5    Select to_number(extractvalue(
      6                       dbms_xmlgen.getxmltype ('select count(*) cnt from "'||table_name||'"'),
      7                       '/ROWSET/ROW/CNT')) rows_in_table
      8      Into nb_lignes
      9      From user_tables
     10      Where table_name = nom_table;
     11  
     12      dbms_output.put_line('La table ' || nom_table || ' a ' || nb_lignes || ' lignes');
     13  end;
     14  /
    Procedure created
     
    SQL> exec compte_table('EMP')
    La table EMP a 14 lignes
    PL/SQL procedure successfully completed
     
    SQL>

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

Discussions similaires

  1. Select dynamique avec execute immediate
    Par BOLARD dans le forum SQL
    Réponses: 7
    Dernier message: 03/06/2008, 16h41
  2. execute immediate into -une variable- ?
    Par betty33 dans le forum SQL
    Réponses: 8
    Dernier message: 19/03/2008, 13h34
  3. Réponses: 4
    Dernier message: 11/10/2007, 08h51
  4. execute immediate select
    Par elharet dans le forum Oracle
    Réponses: 4
    Dernier message: 28/02/2007, 16h52
  5. Equivalents de EXECUTE IMMEDIATE ... RETURNING INTO ... ?
    Par swirtel dans le forum Langage SQL
    Réponses: 4
    Dernier message: 31/05/2005, 10h21

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