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 :

Erreur anormale: command not properly ended


Sujet :

SQL Oracle

  1. #1
    Membre expérimenté
    Avatar de randriano
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 219
    Points : 1 437
    Points
    1 437
    Par défaut Erreur anormale: command not properly ended
    Bonjour,

    Je ne comprends pourquoi il y a erreur sur mon appel de procédure suivant:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    declare
    begin
    USER41.eed_SetGaugeForConnective('EED_OBJ_DEF_ConnectiveEqui');
    end;
     
    ERROR at line 1:
    ORA-00933: SQL command not properly ended
    ORA-06512: at "USER41.EED_SETGAUGEFORCONNECTIVE", line 1
    ORA-06512: at line 3
    Cette procédure existe et est valide mais pourquoi il y a "not properly ended"

    ORA-00933
    Cause: The SQL statement ends with an inappropriate clause


    Ce qui n'est pas mon cas???
    randriano.dvp.com
    Développeur. Product Owner [Agile]. Sites web, mobile apps, système d'information (SI).

  2. #2
    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
    Salut Randriano,

    Montre nous le select qui commence à la ligne 3 de ta procédure. Sinon ci dessous la description de l'erreur en question qui semble à avoir disparu à partir d'Oracle 10R2 (R1 ?)

    ORA-00933 SQL command not properly ended

    Cause: The SQL statement ends with an inappropriate clause. For example, an ORDER BY clause may have been included in a CREATE VIEW or INSERT statement. ORDER BY cannot be used to create an ordered view or to insert in a certain order.

    Action: Correct the syntax by removing the inappropriate clauses. It may be possible to duplicate the removed clause with another SQL statement. For example, to order the rows of a view, do so when querying the view and not when creating it. This error can also occur in SQL*Forms applications if a continuation line is indented. Check for indented lines and delete these spaces.



  3. #3
    Membre expérimenté
    Avatar de randriano
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 219
    Points : 1 437
    Points
    1 437
    Par défaut
    En fait, j'utilise 9i, même si c'est pas récent (2002), c'est fiable

    La ligne 3 c'est:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    USER41.eed_SetGaugeForConnective('EED_OBJ_DEF_ConnectiveEqui');
    Je ne vois d'incorrect là dedans mais ça échoue quand même, c'est pour cela que je pose la question
    randriano.dvp.com
    Développeur. Product Owner [Agile]. Sites web, mobile apps, système d'information (SI).

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Je pense que mnitu faisait référence au code de la procédure USER41.eed_SetGaugeForConnective.

  5. #5
    Membre expérimenté
    Avatar de randriano
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 219
    Points : 1 437
    Points
    1 437
    Par défaut
    Citation Envoyé par Waldar Voir le message
    Je pense que mnitu faisait référence au code de la procédure USER41.eed_SetGaugeForConnective.
    Le contenu de la procédure!!
    Il ne semble que c'est pas dedans le problème, jusqu'à la ligne 20, il n'y a que des déclarations de variables !! Concernant cette procédure, j'utilise 3 curseurs différents, est-ce que c'est peut-être cela le problème? Je répète cette procédure est valide syntaxiquement
    randriano.dvp.com
    Développeur. Product Owner [Agile]. Sites web, mobile apps, système d'information (SI).

  6. #6
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Ah je me demande s'il ne faut pas mettre un / après, que donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    begin
      USER41.eed_SetGaugeForConnective('EED_OBJ_DEF_ConnectiveEqui');
    end;
    /

  7. #7
    Membre expérimenté
    Avatar de randriano
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 219
    Points : 1 437
    Points
    1 437
    Par défaut
    Non ce n'est pas, cela causerait: Encountered the symbol "end-of-file" when expecting one of the following
    randriano.dvp.com
    Développeur. Product Owner [Agile]. Sites web, mobile apps, système d'information (SI).

  8. #8
    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 randriano Voir le message
    ...Je répète cette procédure est valide syntaxiquement
    Est-ce que la procédure utilise du SQL Dynamique (execute immediate ou autre) ?

  9. #9
    Membre expérimenté
    Avatar de randriano
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 219
    Points : 1 437
    Points
    1 437
    Par défaut
    En effet, elle utilise execute immediate, 10 fois même comme suit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    vQueryUpdate := 'UPDATE ' || v_tablename || ' SET Capacity  = ''' || v_Capacity || ''' WHERE IDEquipment ='''|| v_IDEquipment ||'''';
    EXECUTE IMMEDIATE vQueryUpdate;
    randriano.dvp.com
    Développeur. Product Owner [Agile]. Sites web, mobile apps, système d'information (SI).

  10. #10
    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
    Affiche les update via dbms_output au lieur de les exécuter. T'as toujours l'erreur ?

  11. #11
    Membre expérimenté
    Avatar de randriano
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 219
    Points : 1 437
    Points
    1 437
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    	type cursor_eed is ref cursor;
    	cIDEqu cursor_eed;
    	cIDEqu2 cursor_eed;
    BEGIN
     
        vQuerySelect := 'SELECT DISTINCT EDC.IDEquipment FROM ' || v_tablename || ' AS EDC INNER JOIN TB_FRAME AS ELE ON EDC.IDEquipment = ELE.IDEquipment WHERE EDC.Type <> ''Text''';
     
    	OPEN cIDEqu FOR vQuerySelect;
    .......................................
    Enfin, j'ai identifié la ligne à problème c'est sur ce OPEN cIDEqu!!!
    Mais je ne comprends pas pourquoi
    randriano.dvp.com
    Développeur. Product Owner [Agile]. Sites web, mobile apps, système d'information (SI).

  12. #12
    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 randriano Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    	type cursor_eed is ref cursor;
    	cIDEqu cursor_eed;
    	cIDEqu2 cursor_eed;
    BEGIN
     
        vQuerySelect := 'SELECT DISTINCT EDC.IDEquipment FROM ' || v_tablename || ' AS EDC INNER JOIN TB_FRAME AS ELE ON EDC.IDEquipment = ELE.IDEquipment WHERE EDC.Type <> ''Text''';
     
    	OPEN cIDEqu FOR vQuerySelect;
    .......................................
    Enfin, j'ai identifié la ligne à problème c'est sur ce OPEN cIDEqu!!!
    ...
    C'est toujours du SQL dynamique

    Mais je ne comprends pas pourquoi
    C'est pourtant simple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    Connected to Oracle9i Enterprise Edition Release 9.2.0.7.0 
    Connected as mni
     
    SQL> SELECT DISTINCT EDC.ename FROM emp AS EDC INNER JOIN dept AS ELE ON EDC.deptno = ELE.deptno WHERE EDC.dnamer <> 'Text';
     
    SELECT DISTINCT EDC.ename FROM emp AS EDC INNER JOIN dept AS ELE ON EDC.deptno = ELE.deptno WHERE EDC.dnamer <> 'Text'
     
    ORA-00933: La commande SQL ne se termine pas correctement
     
    SQL>

  13. #13
    Membre expérimenté
    Avatar de randriano
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 219
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 219
    Points : 1 437
    Points
    1 437
    Par défaut
    OK

    C'est donc le AS qui n'est pas supporté par Oracle!!! Je portais ce code de SQL Server et je n'ai pas vérifié

    Merci c'était donc le problème
    randriano.dvp.com
    Développeur. Product Owner [Agile]. Sites web, mobile apps, système d'information (SI).

  14. #14
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Customer Success Manager @Vertica
    Inscrit en
    Septembre 2008
    Messages
    8 452
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Customer Success Manager @Vertica
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 452
    Points : 17 820
    Points
    17 820
    Par défaut
    Pour aliaser les tables avec Oracle il ne faut pas utiliser "AS" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    select * from dual d;
     
    DUMMY
    -----
    X
     
    select * from dual as d;
    ORA-00933: la commande SQL ne se termine pas correctement

  15. #15
    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 randriano Voir le message
    ...Je portais ce code de SQL Server et je n'ai pas vérifié
    ...

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

Discussions similaires

  1. ORA-00933: SQL command not properly ended
    Par yupa dans le forum Oracle
    Réponses: 3
    Dernier message: 29/03/2022, 15h12
  2. command not properly ended avec un ORDER BY
    Par Zikas-r dans le forum SQL
    Réponses: 1
    Dernier message: 24/12/2010, 19h52
  3. [AC-2007] ORA-00933: SQL command not properly ended (#933)
    Par zoom61 dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 14/12/2010, 09h38
  4. SQL command not properly ended / Execute immediate
    Par grenouille92 dans le forum SQL
    Réponses: 1
    Dernier message: 01/10/2009, 11h13
  5. Réponses: 1
    Dernier message: 08/02/2008, 17h32

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