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 :

Erreur lors de l'exécution d'une requête avec ADOquery


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Inscrit en
    Août 2006
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 52
    Points : 47
    Points
    47
    Par défaut Erreur lors de l'exécution d'une requête avec ADOquery
    slt,
    J'ai entrain de concevoir une application de gestion d'autorisation d'accés. Le code est le 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
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    //fonction qui permet de retourner le résultat d'une requête r
    function requete(r:string):string;
    begin
    //acces.ADOQuery1.Close;
    acces.ADOquery1.SQL.Clear;
    acces.ADOquery1.SQL.Add(r);
    acces.ADOquery1.open;
    requete:=acces.adoquery1.Fields[0].AsString;
    acces.adoquery1.Close;
    end;
     
    procedure Tacces.validerClick(Sender: TObject);
    var trouve:boolean;
    begin
    trouve:=false;
    adoquery1.First;
    while (not acces.adoquery1.Eof) and (trouve=false) do
    begin
     if (ident.Text=requete('select login from utilisateur where login="'+ident.Text+'"')) and(mdp.Text=requete('select psw from utilisateur where psw="'+mdp.Text+'"'))
        then trouve:=true;
     acces.ADOQuery1.Next;
    end;
    if trouve then
                begin
                 acces.Hide;
                 accueil.Show;
                end
     else MessageDlg('Nom d''utilisateur ou mot de passe erroné.',mtError	, [mbOk], 0);
    end;
    j'ai pas compris le message d'erreur retourné
    Merci pour votre aide.
    Images attachées Images attachées  

  2. #2
    Membre expérimenté
    Avatar de Frank
    Homme Profil pro
    Chef de projet Informatique
    Inscrit en
    Avril 2002
    Messages
    1 095
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 57
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Chef de projet Informatique
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Avril 2002
    Messages : 1 095
    Points : 1 392
    Points
    1 392
    Par défaut
    C'est simple, ta requête est fermée.

    Executes le code en mode pas à pas, tu verras bien à quel moment ça plante

  3. #3
    Membre émérite Avatar de edam
    Homme Profil pro
    Développeur Delphi/c++/Omnis
    Inscrit en
    Décembre 2003
    Messages
    1 894
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Développeur Delphi/c++/Omnis
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 894
    Points : 2 770
    Points
    2 770
    Par défaut
    Citation Envoyé par doolar Voir le message
    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
    //fonction qui permet de retourner le résultat d'une requête r
    function requete(r:string):string;
    begin
    //acces.ADOQuery1.Close;
    acces.ADOquery1.SQL.Clear;
    acces.ADOquery1.SQL.Add(r);
    acces.ADOquery1.open;
    requete:=acces.adoquery1.Fields[0].AsString;
    acces.adoquery1.Close;
    end;
    
    procedure Tacces.validerClick(Sender: TObject);
    var trouve:boolean;
    begin
    trouve:=false;
    adoquery1.First;
    while (not acces.adoquery1.Eof) and (trouve=false) do
    begin
     if (ident.Text=requete('select login from utilisateur where login="'+ident.Text+'"')) and(mdp.Text=requete('select psw from utilisateur where psw="'+mdp.Text+'"'))
        then trouve:=true;
     acces.ADOQuery1.Next;
    end;
    end;
    tu utlise la même adoquery

Discussions similaires

  1. Erreur bizarre lors de l'exécution d'une requête
    Par Mr. NoReaction dans le forum JDBC
    Réponses: 1
    Dernier message: 05/11/2008, 21h22
  2. [PostgreSQL] [PostGreSQL] Obtention d'une erreur lors de l'exécution d'une requête
    Par cbombabill dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 06/03/2008, 11h56
  3. Erreur lors de la conversion d'une requête SELECT en DELETE
    Par SamLeChiseuji dans le forum Requêtes et SQL.
    Réponses: 9
    Dernier message: 11/07/2007, 15h09
  4. [MySQL] Erreur lors de la construction d'une requête
    Par gaetan24 dans le forum PHP & Base de données
    Réponses: 23
    Dernier message: 06/04/2007, 15h45
  5. Réponses: 1
    Dernier message: 05/12/2005, 23h24

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