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 :

Utilisation d'une variable dans FROM


Sujet :

PL/SQL Oracle

  1. #1
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Portugal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2011
    Messages : 33
    Par défaut Utilisation d'une variable dans FROM
    Bonjour, j'aurai besoin d'utiliser une variable dans un FROM mais SQL Developer ne me l'autorise pas et m'indique le code erreur suivant

    ORA-06550: line 39, column 19:
    PL/SQL: ORA-00942: table or view does not exist

    Existe t-il un moyen de la faire ou une méthode pour contourer se problème?

    Coordialement

  2. #2
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Utilise EXECUTE IMMEDIATE pour construire ta requête.

  3. #3
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Portugal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2011
    Messages : 33
    Par défaut
    En lisant le tutoriel, je n'ai pas trouvé mon bonheur.
    Voici mon code qui m'affiche l'erreur citée au dessus.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT tableName INTO nomTable FROM Four 
    SELECT * FROM nomTable

  4. #4
    Expert confirmé 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
    Par défaut
    Citation Envoyé par orafrance Voir le message
    Utilise EXECUTE IMMEDIATE pour construire ta requête.

  5. #5
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Portugal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2011
    Messages : 33
    Par défaut
    Même avec le tutoriel, je n'arrive pas a obtenir le résultat escompté serai t-il possible d'avoir le code avec quel explication?

  6. #6
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Ce serait pas mieux d'avoir ton code et le message d'erreur ?

  7. #7
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Portugal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2011
    Messages : 33
    Par défaut
    Je l'ai poster au-dessus.

  8. #8
    Expert confirmé 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
    Par défaut
    Il n'y a pas d'execute immediate dans le code que vous avez posté.

  9. #9
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    je ne vois pas de EXECUTE IMMEDIATE dans votre message Faudrait faire un minimum de recherche tout de même... merci

  10. #10
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Portugal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2011
    Messages : 33
    Par défaut
    L'utilisation d'un curseur est-elle aussi possible? Car je n'arrive pas a comprendre le execute immediate.

    Cette autre bout de code vous parrait-il correct?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    UPDATE champModifer  SET nomTable = champCaract WHERE colonne1 = chaine1
             AND colonne2   = chaine2 AND colonne3   = chaine3;
          IF SQL%RowCount = 0 Then
            INSERT INTO nomTable (colonne1, colonne2, colonne3, champModifier)          
            VALUES (chaine1, chaine2, chaine3, champCaract);
    champModifier, champCaract et nomTable étant des variables.
    Ainsi que chaine1, chaine2, chaine3.

  11. #11
    Expert éminent
    Avatar de orafrance
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    15 967
    Détails du profil
    Informations personnelles :
    Âge : 48
    Localisation : France

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Par défaut
    Non

    c'est quand même pas compliqué : http://sheikyerbouti.developpez.com/...mmediate/#L4.5

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    PROCEDURE    Modifie_lignes ( nomTable IN VARCHAR2, champModifier IN VARCHAR2, champCaract  IN VARCHAR2) 
    IS
       LC$Requete        VARCHAR2(256) ;
    BEGIN
       LC$Requete:= 'UPDATE :1 SET :2 = :3 WHERE colonne1 = chaine1';
       EXECUTE IMMEDIATE LC$Requete USING nomTable,champModifier ,champCaract ;
       IF SQL%RowCount = 0 THEN
         LC$Requete:= 'INSERT INTO :1(colonne1, colonne2, colonne3, :2) VALUES (chaine1, chaine2, chaine3, :3)';
            EXECUTE IMMEDIATE LC$Requete USING nomTable,champModifier ,champCaract ;
       END IF;
    END ;

  12. #12
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2011
    Messages
    33
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Portugal

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2011
    Messages : 33
    Par défaut
    Merci pour votre aide j'ai réussi avec vos conseils.

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 15/02/2006, 17h24
  2. [VB.NET] Utilisation d'une variable dans une autre form (!)
    Par neuropathie dans le forum Windows Forms
    Réponses: 5
    Dernier message: 08/12/2005, 13h09
  3. [vb.net] utilisation d'une variable dans le code
    Par arnolem dans le forum Windows Forms
    Réponses: 9
    Dernier message: 30/09/2005, 19h22
  4. Réponses: 9
    Dernier message: 05/07/2005, 08h37
  5. Pl/SQL utilisation d'une variable dans un select
    Par larg dans le forum PL/SQL
    Réponses: 17
    Dernier message: 30/11/2004, 17h08

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