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 :

requete / violation d'accès


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Femme Profil pro
    Inscrit en
    Avril 2004
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 75
    Points : 59
    Points
    59
    Par défaut requete / violation d'accès
    bonjour
    je reviens avec ce probleme de violation d'accès
    je vais essayre d'etre claire:

    Sous SQL ceci marche bien :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    With formbddsql.ADOQuery1 Do
      Begin
        SQL.Clear;
     
        SQL.Add('select count(Pin_Essai.pin_seqno) as nb');
        SQL.Add(' FROM Pin INNER JOIN Pin_Essai ON Pin.pin_seqno = Pin_Essai.pin_seqno INNER JOIN Essai ON Pin_Essai.ess_seqno = Essai.ess_seqno ');
        SQL.Add(' where Essai.ess_num= ('+quotedStr(formbddsql.EditEssai.text)+') and  Pin.pin_num= ('+quotedStr(formbddsql.EditPin.text)+') ');
     
        Adoquery1.open;
      End;
     
    nb := adoquery1.FieldByName('nb').AsInteger;
    et la mêem requete avec access j'ai " le projet a provoqué une classe d'exception EAccessViolation .. violation d'accès à l'adresse .. dans le module msjet40.dll ..."
    puis après ça me met aussi "syntaxError missing operator"

    alors j'essaye de refaire une requete équivalente que je fabrique dans access (avec son assistant graphique). je fais quasiment copier/coller du code SQL qu"elle génère.
    et je la mets toute seule dans un bouton :

    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
    procedure TFormBddSql.Button2Click(Sender: TObject);
    var nb : integer;
    begin
    With formbddsql.ADOQuery1 Do
      Begin
        SQL.Clear;
     
     
        SQL.Add('SELECT Count(Pin_Essai.pin_seqno) AS CountOfpin_seqno');
        SQL.Add(' FROM Pin INNER JOIN (Essai INNER JOIN Pin_Essai ON');
        SQL.Add(' Essai.ess_seqno = Pin_Essai.ess_seqno) ON Pin.pin_seqno = Pin_Essai.pin_seqno');
        SQL.Add(' GROUP BY Pin.pin_num, Essai.ess_num');
        SQL.Add(' HAVING (((Pin.pin_num)=('+quotedStr(formbddsql.EditPin.text)+'))');
        SQL.Add(' AND ((Essai.ess_num)=('+quotedStr(formbddsql.EditEssai.text)+')))');
     
        Adoquery1.open;
      End;
     
    nb := adoquery1.FieldByName('CountOfpin_seqno').AsInteger;
    showmessage(inttostr(nb));
     
    end;
    et là j'ai tjours cette erreur de violation (mais elle marche sous SQL SERver)
    par contre après le résultat du showmessage est juste.

    je débute alors c'est peut-etre une erreur toute bete ?? mais je vois pas ...
    si qqun avait la moindre piste

  2. #2
    Membre confirmé Avatar de lper
    Profil pro
    Inscrit en
    Juin 2004
    Messages
    398
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Juin 2004
    Messages : 398
    Points : 641
    Points
    641
    Par défaut
    bonjour,
    je crois que l'erreur est :
    a remplacer parTu ne dois pas pointer sur le bon query, de plus, tu devrais faire un close avant le SQL.clear.

  3. #3
    Membre du Club
    Femme Profil pro
    Inscrit en
    Avril 2004
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 75
    Points : 59
    Points
    59
    Par défaut
    salut
    merci
    mais non , j'ai toujours mon erreur malgré ces deux ajouts
    (c'est une erreur qui n apparait pas si je lance l'exécutable en dehors de delphi)

  4. #4
    Membre actif
    Homme Profil pro
    Responsable d'une MOE bancaire
    Inscrit en
    Juillet 2003
    Messages
    261
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Responsable d'une MOE bancaire

    Informations forums :
    Inscription : Juillet 2003
    Messages : 261
    Points : 226
    Points
    226
    Par défaut
    Juste une petite question?

    T'as vérifié la ligne qui déclenche l'exception?

    La ligne où il y a Open ou celle d'apres? c tres important!

  5. #5
    Membre du Club
    Femme Profil pro
    Inscrit en
    Avril 2004
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 75
    Points : 59
    Points
    59
    Par défaut
    salut
    merci, en vérifaiant d'un sens ça m'a résolu le pb
    Citation Envoyé par SegmentationFault
    T'as vérifié la ligne qui déclenche l'exception?
    alors j'ai vérifié et c'est la ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SQL.Add(' FROM Pin INNER JOIN (Essai INNER JOIN Pin_Essai ON');
    alors à tout hazard je l'ai remontée comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SQL.Add('SELECT Count(Pin_Essai.pin_seqno) AS CountOfpin_seqno FROM Pin INNER JOIN (Essai INNER JOIN Pin_Essai ON');
    et maintenant je n'ai plus l'erreur
    alors pour voir je refais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
        SQL.Add('SELECT Count(Pin_Essai.pin_seqno) AS CountOfpin_seqno');
        SQL.Add(' FROM Pin INNER JOIN (Essai INNER JOIN Pin_Essai ON');
    comme ça toujours l'erreur !!
    bref en mettant la ligne dans "un seul SQL.Add" c'est bon mais j'aimerais bien comprendre

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

Discussions similaires

  1. "violation d'acces à l'adresse" en sortie de primi
    Par netah25 dans le forum C++Builder
    Réponses: 20
    Dernier message: 18/01/2005, 11h22
  2. ReportPrinterDialog (QR2) : violation d'accès..
    Par Harry dans le forum Bases de données
    Réponses: 5
    Dernier message: 30/12/2004, 14h04
  3. [XMLDocument] Violation d'accès
    Par xant dans le forum Composants VCL
    Réponses: 8
    Dernier message: 29/09/2004, 15h39
  4. Violation d'acces apres Execute
    Par SegmentationFault dans le forum Connexion aux bases de données
    Réponses: 6
    Dernier message: 10/08/2004, 16h23
  5. Violation d'accès apres Close
    Par SegmentationFault dans le forum Bases de données
    Réponses: 3
    Dernier message: 05/07/2004, 16h46

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