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

Oracle Discussion :

[PL/SQL] [9i] Ordre Create dans un Script


Sujet :

Oracle

  1. #1
    Membre régulier
    Inscrit en
    Juin 2003
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juin 2003
    Messages : 156
    Points : 85
    Points
    85
    Par défaut [PL/SQL] [9i] Ordre Create dans un Script
    Bonjour,

    Une petite question pour commencer doucement la semaine

    Le compilateur SQL+ me jette avec le code suivant :
    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
     
      requete := '
       CREATE TABLE RDD_TRANSCO_NIR_RJT (
        NUMCMR   VARCHAR2(3) NULL,
        NIR  VARCHAR2(13)   NULL,
        CLE  VARCHAR2(2)   NULL,  
        TYPE1   VARCHAR2(1)  NULL,
        RANG   VARCHAR2(1)  NULL,
        SEQ_ASS_AYD VARCHAR2(7) NULL,
        AUTRE_MEMBRE VARCHAR2(2) NULL, 
        NUM_INTERNE_BDU VARCHAR2(13) NULL,
        DATE_RJT  TIMESTAMP NULL,
        LIB_RJT  VARCHAR(100)  NULL
       );';  
      EXECUTE IMMEDIATE requete;
    PLS-00103: Symbole "CREATE" rencontré à la place d'un des
    symboles suivants :
    begin end function package pragma procedure form
    Merci, Fred

  2. #2
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Essaie sans le ;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    requete := '
       CREATE TABLE RDD_TRANSCO_NIR_RJT (
        NUMCMR   VARCHAR2(3) NULL,
        NIR  VARCHAR2(13)   NULL,
        CLE  VARCHAR2(2)   NULL,  
        TYPE1   VARCHAR2(1)  NULL,
        RANG   VARCHAR2(1)  NULL,
        SEQ_ASS_AYD VARCHAR2(7) NULL,
        AUTRE_MEMBRE VARCHAR2(2) NULL, 
        NUM_INTERNE_BDU VARCHAR2(13) NULL,
        DATE_RJT  TIMESTAMP NULL,
        LIB_RJT  VARCHAR(100)  NULL
       )';

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    essaye ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    requete := 'CREATE TABLE RDD_TRANSCO_NIR_RJT (
        NUMCMR   VARCHAR2(3) ,
        NIR  VARCHAR2(13),
        CLE  VARCHAR2(2)   ,  
        TYPE1   VARCHAR2(1)  ,
        RANG   VARCHAR2(1)  ,
        SEQ_ASS_AYD VARCHAR2(7) ,
        AUTRE_MEMBRE VARCHAR2(2) , 
        NUM_INTERNE_BDU VARCHAR2(13) ,
        DATE_RJT  TIMESTAMP ,
        LIB_RJT  VARCHAR(100)  
       )';
    NULL ne sert à rien et la chaîne ne doit pas contenir de ;

    Pour le débuggage tu arriveras surement à te débrouiller seul

  4. #4
    Membre régulier
    Inscrit en
    Juin 2003
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juin 2003
    Messages : 156
    Points : 85
    Points
    85
    Par défaut
    Merci mais ... mauvaise pioche, le message d'erreur résiste !

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    mais je vois que tu es sous SQL*Plus... donc soit tu fais le CREATE sans execute immediate, sois tu fais du PL/SQL avec BEGIN/END

  6. #6
    Rédacteur

    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    2 320
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 2 320
    Points : 3 798
    Points
    3 798
    Par défaut
    Execute immediate doit être compris dans un bloc PL/SQL :
    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
    SQL> drop table test ; 
    Table supprimée.
    SQL>  execute immediate ' create table test (a number ) '  ;
    BEGIN immediate ' create table test (a number ) '  ; END;
                    *
    ERREUR à la ligne 1 :
    ORA-06550: line 1, column 17:
    PLS-00103: Encountered the symbol " create table test (a number ) " when
    expecting one of the following:
    := . ( @ % ;
    The symbol ":=" was substituted for " create table test (a number ) " to
    continue.
     
    SQL>  begin 
      2   execute immediate ' create table test (a number ) '  ;
      3   end ; 
      4  /
    Procédure PL/SQL terminée avec succès.
    SQL> desc test 
     Nom                                       NULL ?   Type
     ----------------------------------------- -------- ----------------------------
     A                                                  NUMBER

  7. #7
    Membre régulier
    Inscrit en
    Juin 2003
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juin 2003
    Messages : 156
    Points : 85
    Points
    85
    Par défaut
    Je compile mon script sous SQL+ mais mon code n'est pas directement mis dans SQL+. L'odre CREATE est inclus dans une FUNCTION elle-même dans un package ! Donc je ne peux qu'utiliser le SQL dynamique pour créer depuis le script, mais ça ne fonctionne pas tel que je l'ai écrit.

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    faudrait le code complet dans ce cas

  9. #9
    Membre régulier
    Inscrit en
    Juin 2003
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juin 2003
    Messages : 156
    Points : 85
    Points
    85
    Par défaut
    Brut de fonderie

    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
    44
    45
    46
    47
    48
    49
    50
     
     /*
     Description : création de la table de transo RDD_TRANSCO_NIR
     */
     CREATE OR REPLACE FUNCTION cp_tab_transco RETURN NUMBER IS
     
      requete VARCHAR2(1000);
     BEGIN
     
      requete := 'DROP TABLE RDD_TRANSCO_NIR;';
      EXECUTE IMMEDIATE requete;
     
      requete := 'DROP TABLE RDD_TRANSCO_NIR_RJT;';
      EXECUTE IMMEDIATE requete;
     
      requete := '
       CREATE TABLE RDD_TRANSCO_NIR (
        NUMCMR   VARCHAR2(3) NULL,
        NIR  VARCHAR2(13)   NULL,
        CLE  VARCHAR2(2)   NULL, 
        TYPE1   VARCHAR2(1)  NULL,
        RANG   VARCHAR2(1)  NULL,
        SEQ_ASS_AYD VARCHAR2(7) NULL,
        AUTRE_MEMBRE VARCHAR2(2) NULL,
        NUM_INTERNE_BDU VARCHAR2(13) NULL);';
      EXECUTE IMMEDIATE requete; 
     
      -- création d'un index
      requete := 'CREATE INDEX ITRS ON RDD_TRANSCO_NIR(NUMCMR, NIR, TYPE1, RANG);';
      EXECUTE IMMEDIATE requete;  
     
      requete := '
       CREATE TABLE RDD_TRANSCO_NIR_RJT (
        NUMCMR   VARCHAR2(3) NULL,
        NIR  VARCHAR2(13)   NULL,
        CLE  VARCHAR2(2)   NULL,  
        TYPE1   VARCHAR2(1)  NULL,
        RANG   VARCHAR2(1)  NULL,
        SEQ_ASS_AYD VARCHAR2(7) NULL,
        AUTRE_MEMBRE VARCHAR2(2) NULL, 
        NUM_INTERNE_BDU VARCHAR2(13) NULL,
        DATE_RJT  TIMESTAMP NULL,
        LIB_RJT  VARCHAR(100)  NULL);';  
      EXECUTE IMMEDIATE requete;  
     
      COMMIT;
     
      RETURN NULL;
     
     END cp_tab_transco;

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    pourquoi faire ça en PL/SQL ? Quel est l'intérêt d'avoir une fonction plutôt qu'une procédure ? As-tu essayé d'afficher les requêtes pour les tester sous SQL*Plus ?

    Enfin, le ; ne doit pas être inclus dans la chaîne comme je l'ai déjà dit

  11. #11
    Membre régulier
    Inscrit en
    Juin 2003
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juin 2003
    Messages : 156
    Points : 85
    Points
    85
    Par défaut
    L'ordre de création fonctionne de façon intrinsèque sous SQL+.

    Je fais ça en PL/SQL car je voulais avoir tout mon code inclus dans des packages mais Ok une procédure conviendrait. Cela dit, je ne pense pas que ça change mon erreur, si ?

    Ok pour le ';' je les enlève définitivement !

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    un copier/coller de toute l'erreur STP

  13. #13
    Membre régulier
    Inscrit en
    Juin 2003
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juin 2003
    Messages : 156
    Points : 85
    Points
    85
    Par défaut
    Avertissement : Corps de package créé avec erreurs de compilation.
    Erreurs pour PACKAGE BODY PKGCOMPLEMENTS :
    LINE/COL ERROR
    -------- -----------------------------------------------------------------
    55/2 PLS-00103: Symbole "CREATE" rencontré à la place d'un des
    symboles suivants :
    begin end function package pragma procedure form

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

    Informations forums :
    Inscription : Janvier 2004
    Messages : 15 967
    Points : 19 075
    Points
    19 075
    Par défaut
    j'ai compris... tu fais un CREATE OR REPLACE dans un package

    merci de revoir la doc et tu devrais comprendre ton erreur

  15. #15
    Membre régulier
    Inscrit en
    Juin 2003
    Messages
    156
    Détails du profil
    Informations forums :
    Inscription : Juin 2003
    Messages : 156
    Points : 85
    Points
    85
    Par défaut
    Oh mince, effectivement, c'est un copier / coller malheureux de là où était le code avant. Désolé, je suis confus ! Je me suis focalisé sur le CREATE TABLE mais l'erreur n'était pas là.

    N'en parlons plus !! Merci !!

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

Discussions similaires

  1. Msg 2714 (objet deja existant) dans un script SQL Server
    Par Makrier dans le forum MS SQL Server
    Réponses: 1
    Dernier message: 06/11/2006, 11h40
  2. [SQL] Traitement de plusieurs requêtes .SQL dans un script PHP?
    Par M4x dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 19/03/2006, 19h59
  3. [Sql] erreur dans un script
    Par fyren` dans le forum Oracle
    Réponses: 9
    Dernier message: 02/02/2006, 23h44
  4. Réponses: 2
    Dernier message: 16/01/2006, 15h07
  5. [MySQL] Problème de requêtes SQL dans un script
    Par Nefret dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 08/09/2005, 15h08

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