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

Delphi Discussion :

delphi adotable beforpost


Sujet :

Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    226
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2009
    Messages : 226
    Par défaut delphi adotable beforpost
    bonjour
    j'ai une table adotable sur la fiche un dbnavigateur
    j'ai rempli des dbedit pour la table et lors de la validation
    des données je regarde si la données "reference n'est pas un doublons
    avec la commande beforpost
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    procedure TfPrimo.ADOTable1BeforePost(DataSet: TDataSet);
        var
    ref:string;
    begin
     ref:=fprimo.DBEdit1.Text;
      if adotable1.Locate('reference',ref,[])= true then
     
        begin
       showmessage(' reference existante');
       fprimo.ADOTable1.Cancel;
       end;
    end;
    mais j'obtiens une erreur stack overflow error

    merci pour aide

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 658
    Billets dans le blog
    65
    Par défaut
    Bonjour,

    quelque part c'est logique. Vous êtes en train de modifier ADOTable1 disons que vous avez "un curseur" sur la ligne en cours de modification et par votre instruction de recherche sur cette même table adotable1.Locate('reference',ref,[]) vous déplacer le curseur ailleurs. Que vous ayez une erreur n'est donc pas surprenant.

    Si vous voulez vérifier, il aurait fallu que la recherche soit sur un autre ensemble de données ou une interrogation par SQL
    d'un autre côté s'il s'agit d'une clé , un contrainte d'index unique permettrait de lever une erreur qu'il suffirait de gérer au niveau du Post avec un bloc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    try 
     Adotable1.Post; 
    except 
       on E:EdatabaseError do    // affinable
         begin 
            showmessage(' reference existante');
            ADOTable1.Cancel;
         end;
    end;
    parlons maintenant de votre code, j'ai remarqué que vous aviez tendance à ajouter, inutilement, le nom de la forme (encombrant inutilement la lecture)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    procedure TfPrimo.ADOTable1BeforePost(DataSet: TDataSet);
    begin
      if adotable1.Locate('reference',DBEdit1.Text,[])= true then
        begin
          showmessage(' reference existante');
         ADOTable1.Cancel;
       end;
    end;
    et enfin renommez vos composants afin de rendre plus explicite, pensez "maintenance"

  3. #3
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 094
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 094
    Par défaut
    Il ne faut pas appeler Cancel depuis BeforePost mais un Abort qui lui fera le Cancel.
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

Discussions similaires

  1. Delphi: Ajouter un champ a une base de donnée AdoTable (MDB)
    Par DavKli dans le forum Bases de données
    Réponses: 4
    Dernier message: 23/08/2018, 05h51
  2. Différences entre Delphi et Visual Basic ?
    Par Anonymous dans le forum Débats sur le développement - Le Best Of
    Réponses: 75
    Dernier message: 30/03/2009, 20h09
  3. [Kylix] Migration delphi -> kylix
    Par Christian dans le forum EDI
    Réponses: 1
    Dernier message: 03/04/2002, 22h50
  4. Réponses: 4
    Dernier message: 27/03/2002, 11h03
  5. Réponses: 2
    Dernier message: 20/03/2002, 23h01

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