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 :

[ADO][SqlServer] Pb avec les paramètres dans les expressions


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    158
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 158
    Par défaut [ADO][SqlServer] Pb avec les paramètres dans les expressions
    Bonjour,

    Dans le cas d'une migration BDE en ADO, je me retrouve avec le problème suivant.

    Lorsque dans une requête, il y a des paramètres à la fois dans l'expression et dans sa close where, ma requête "ADO" lors de l'évaluation du paramcheck plante sur "mémoire insuffisante".

    Si je prends ce cas 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
    With MaRequete do
    begin
    Close;
    SQL.Clear;
    SQL.Add('select Monchamp1,(select Monchamp2 from LaTable2 where 
    Monchamp2 = :PChamp2)
    from LaTable1 ');
    SQL.Add('Where Monchamp1 = :PChamp1);
    ParamCheck := True;
    ParamByName('PChamp1').Value := 'Test';
    ParamByName('PChamp2').Value := 'Test';
    Open;
    end;
    cela plante ( Pour info en BDE cela ne pose aucun problème)

    par contre dans les 2 cas qui suivent cela passe normalement

    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
      // Le paramètre est uniquement dans la close where
       
      With MaRequete do
    begin
    Close;
    SQL.Clear;
    SQL.Add('select Monchamp1,(select Monchamp2 from LaTable2 where 
    Monchamp2 = 'Test')
    from LaTable1 ');
    SQL.Add('Where Monchamp1 = :PChamp1);
    ParamCheck := True;
    ParamByName('PChamp1').Value := 'Test';
    //ParamByName('PChamp2').Value := 'Test';
    Open;
    end;
    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
     // Le paramètre est uniquement dans l’expression
       
      With MaRequete do
    begin
    Close;
    SQL.Clear;
    SQL.Add('select Monchamp1,(select Monchamp2 from LaTable2 where 
    Monchamp2 = 'Test')
    from LaTable1 ');
    SQL.Add('Where Monchamp1 = 'Test');
    ParamCheck := True;
    //ParamByName('PChamp1').Value := 'Test';
    ParamByName('PChamp2').Value := 'Test';
    Open;
    end;
    Avez vous une idée , d’où pourrait venir le problème ?

    Merci pour vos réponses.

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 236
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 236
    Par défaut
    Mon dieu mais quelle requete horrible

    Elle doit faire quoi ta requete ?

    Le MonChamp1 = le MonChamp2 ?

    Des requetes de ce style c'est à banir ...

    Donne ous des infos pour qu'on te sorte une requete beaucoup mieux que celle la.
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  3. #3
    Membre émérite Avatar de slimjoe
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2005
    Messages : 647
    Par défaut
    Salut!

    En ADO, la méthode ParamByName est encapsulée dans l'objet Parameters. Il faut donc faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
      with MaRequete do
      begin
        Close;
        SQL.Clear;
        SQL.Add('select Monchamp1, (select Monchamp2 from LaTable2 where Monchamp2 = :PChamp2) from LaTable1');
        SQL.Add('Where Monchamp1 = :PChamp1');
        ParamCheck := True;
        Parameters.ParamByName('PChamp1').Value := 'Test';
        Parameters.ParamByName('PChamp2').Value := 'Test';
        Open;
      end;
    Ceci dit, avec le message d'erreur, c'est plus facile de diagnostiquer ("ça plante" n'est pas un diagnostic valide

  4. #4
    Membre émérite Avatar de slimjoe
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2005
    Messages : 647
    Par défaut
    Citation Envoyé par Malatar
    Mon dieu mais quelle requete horrible

    [...]

    Des requetes de ce style c'est à banir ...

    Donne ous des infos pour qu'on te sorte une requete beaucoup mieux que celle la.
    +1

    Parfaitement d'accord!

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    158
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 158
    Par défaut
    Bonjour,

    je vous remercie pour vos réponses.

    J'ai mis une requête générique pour l'exemple, car je ne peux pas vous mettre la requête en prod qui est trop longue,
    mais c'était surtout le principe que je voulais avoir avec vous
    c'est à dire le fait d'utiliser des paramètres à la fois dans les expressions et dans la close where.

    Merci

  6. #6
    Expert confirmé
    Avatar de Cl@udius
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2006
    Messages
    4 878
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 4 878
    Par défaut
    Salut

    Même si elle est longue, tu peux quand même nous la montrer cette requête.
    Car je suis d'accord avec Malatar et SlimJoe, ton exemple de requête n'a rien de générique !!!

    @+ Claudius

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    158
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2005
    Messages : 158
    Par défaut
    Voici exprimée je l'espère de manière plus clair, le type de requête que je ne peux pas exécuter en ADO

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select col,(select col from tab where col= :X1) from tab where col = :X2
    En essayant de coller ce SQL dans un ADOQuery en paramcheck à TRUE

    on obtient en mode design 'Violation accès dans ntdll.dll' puis à l'execution 'Violation d'accès dans rtl70.bpl' et dynamiquement par le code 'Mémoire insuffisante pour cette opération'.

    Merci
    Pour votre aide

    (PS : S'il le faut , je vous post la requête complète)

  8. #8
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 236
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 236
    Par défaut
    Ce que l'on te demande surtout c'est qu'est ce que tu veux faire avec ta requete finale.
    Une requete avec un select dans ses champs, c'est normalement à ne jamais faire.
    Je suis sûr qu'on peut transformer cette requete en une requete avec des jointures propres (et je suis sûr aussi qu'elle sera largement plus rapide à exécuter).
    Modérateur Delphi

    Le guide du bon forumeur :
    __________
    Rayek World : Youtube Facebook

  9. #9
    Membre émérite Avatar de slimjoe
    Homme Profil pro
    Inscrit en
    Juin 2005
    Messages
    647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Canada

    Informations forums :
    Inscription : Juin 2005
    Messages : 647
    Par défaut
    Citation Envoyé par pitango
    Voici exprimée je l'espère de manière plus clair, le type de requête que je ne peux pas exécuter en ADO

    on obtient en mode design 'Violation accès dans ntdll.dll' puis à l'execution 'Violation d'accès dans rtl70.bpl' et dynamiquement par le code 'Mémoire insuffisante pour cette opération'.

    Ce code fonctionne parfaitement chez moi (D7 sur WinVista et SQL Express, MaRequete est un TADOQuery) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
      with MaRequete do
      begin
        Close;
        SQL.Clear;
        SQL.Add('select Monchamp1, (select Monchamp2 from LaTable2 where Monchamp2 = :PChamp2) from LaTable1');
        SQL.Add('Where Monchamp1 = :PChamp1');
        ParamCheck := True;
        Parameters.ParamByName('PChamp1').Value := 'Test';
        Parameters.ParamByName('PChamp2').Value := 'Test';
        Open;
      end;

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 06/08/2009, 17h09
  2. les classes et les templates dans les plugins
    Par asoka13 dans le forum C++
    Réponses: 22
    Dernier message: 24/01/2008, 17h11
  3. Réponses: 2
    Dernier message: 22/08/2007, 12h46
  4. Réponses: 4
    Dernier message: 11/09/2006, 16h55
  5. Les polices dans les tables et les requêts
    Par zooffy dans le forum Access
    Réponses: 3
    Dernier message: 21/06/2006, 11h06

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