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

Bases de données Delphi Discussion :

[ORACLE][ADOQuery] Probleme de syntaxe


Sujet :

Bases de données Delphi

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Août 2002
    Messages
    146
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2002
    Messages : 146
    Points : 76
    Points
    76
    Par défaut [ORACLE][ADOQuery] Probleme de syntaxe
    Salut

    Je rencontre un probleme lors de l'adaptation d'un soft écrit pour MSSQL sur ORACLE

    Si je rajoute des ';' après chaque commande (INSERT et SELECT), il crée une exception ORA-00911 : caractère non valide, si je n'en mets pas (ou juste apres le SELECT, autre exception : ORA-00933 La commande SQL ne se termine pas correctement.

    Quelqu'un pourrait-il m'apporter de l'aide quant à la correction de la syntaxe ?

    Merci

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
       qryAddRecordInItems.SQL.Clear;
       qryAddRecordInItems.SQL.Add('INSERT INTO ITEMS (NAME, ABREVIATION, HIDDEN, EXTERN_ID, BARCODE, ENABLED, ITEM_TYPE, ITEM_CAT) VALUES (:NAME, :ABREVIATION, :HIDDEN, :EXTERN_ID, :BARCODE, :ENABLED, :ITEM_TYPE, :ITEM_CAT) ');
       qryAddRecordInItems.SQL.Add('SELECT items_seq.CURRVAL AS ID from dual');
     
    qryAddRecordInTreeStructure.SQL.Clear;
        qryAddRecordInTreeStructure.SQL.Add('INSERT INTO TREE_STRUCTURE(BRANCH_NAME, PARENT, HIDDEN, SYSTEM) VALUES (:BRANCH_NAME, :PARENT, '#39'False'#39', '#39'False'#39') ');
        qryAddRecordInTreeStructure.SQL.Add('SELECT tree_structure_seq.CURRVAL AS ID from dual');
    NB : Les commandes ont directement été copiées du DFM (pour les #39'False'#39 ...)

    Merci pour votre aide

  2. #2
    Expert confirmé

    Profil pro
    Leader Technique
    Inscrit en
    Juin 2005
    Messages
    1 756
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Leader Technique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2005
    Messages : 1 756
    Points : 4 170
    Points
    4 170
    Par défaut
    Et bien je dirais que Oracle et SQL Server ne se comportent pas de la même façon :

    Sous SQL Server, il est possible de grouper plusieurs statement SQL à l'intérieur d'un seul batch et de le soumettre en une seule fois au serveur. Donc avec SQL Server, tu pouvais faire une seule commande qui exécute à la fois l'insert et le select de l'identity généré.

    En revanche sous Oracle, ce n'est pas possible de cette façon. Une requête SQL ne peut contenir qu'un seul statement.
    Donc tu dois faire l'insert et le select en deux requêtes distinctes.

    Je pense que pour grouper les deux instructions dans une seule commande avec Oracle, il faut soumettre un bloc PL/SQL au serveur et non plus un batch.
    C'est à dire qu'il faut mettre les ';' pour séparer les statements, mais il faut encadrer le tout avec un BEGIN END.
    Par contre, dans ce cas, je crois que tu ne peux pas renvoyer de SELECT dans le bloc...

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Août 2002
    Messages
    146
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Août 2002
    Messages : 146
    Points : 76
    Points
    76
    Par défaut
    Pour recherche l'ID inseré à la fois en oracle et MSSQL tout en utilisant le meme composant (ici TADOCommand) il faut changer la syntaxe des commandes

    En Oracle : RETURNING ID INTO :NewID

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    INSERT INTO ITEMS (NAME, ABREVIATION, HIDDEN  ) VALUES 
    (:NAME, :ABREVIATION, :HIDDEN)
    RETURNING ID INTO :NewID

    Pour MSSQL : SET :NewID = SCOPE_IDENTITY()

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    INSERT INTO ITEMS (NAME, ABREVIATION, HIDDEN) VALUES (:NAME, :ABREVIATION, :HIDDEN);
    SET :NewID = SCOPE_IDENTITY()
    Il faut adapter les valeurs de parametres : ftInteger pour les Boolean (marche pour les 2 TSQL et Oracle)
    Pour les types ftString, il est nessecaire de spécifier le nombre de caracteres (size)

    Pour le parametre de retour, mettre aussi Direction à pdInputOutput

    Il existe peut etre d'autres méthodes, mais celle ci fonctionne...

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

Discussions similaires

  1. Probleme de Syntaxe? oracle 11g
    Par Mad_Max_ dans le forum Oracle
    Réponses: 1
    Dernier message: 18/02/2010, 14h00
  2. [VB.NET] Probleme de syntaxe
    Par microthib dans le forum Windows Forms
    Réponses: 4
    Dernier message: 17/03/2005, 13h49
  3. probleme fonction syntaxe
    Par gIch dans le forum Général JavaScript
    Réponses: 8
    Dernier message: 28/02/2005, 09h52
  4. [Débutante] Problèmes de syntaxe
    Par new_wave dans le forum Prolog
    Réponses: 4
    Dernier message: 02/11/2004, 18h39
  5. Problemes de syntaxe
    Par maahta dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 01/10/2003, 13h40

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