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 :

probleme avec une auto-incremente


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    121
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2006
    Messages : 121
    Points : 59
    Points
    59
    Par défaut probleme avec une auto-incremente
    Bonjour à tous!
    Voici, j'ai deux tables, un maitre et un esclave, la table Contact est maitre de la table Factures.
    Dans ma table Factures, j'ai un champ appelé Numfact, il contient les numeros de factures. je gère par programmation son auto increment .
    Le probleme se situe à ce niveau, la table Contact contient les noms des contacts et ces contacts ont des factures. Lorsque je voudrais ajouter une nouvelle facture , il le fait selon le nombre de factures de ce contact et non selon le nombre de factures de la table.
    c'est à dire ceci:
    si j'ajoute premièrement dans ma table Contact un nouveau contact et que je veux créer un facture à ce dernier , il commencera par 1, or il y a deja des factures dans la table Factures, et le numero 1 existe deja .
    il ne tient pas compte de la dernière facture de la table , mais de la dernière facture du contact. Pour ce contact , c'est sa première facture. il incremente selon le nombre de factures de chaque contact et non selon le nombre de facture de la table.
    Or je voudrais qu'il tienne compte de la dernière facture de la table et non celle du Contact.
    voici mon code , dans l'evenement OnShow de ma form ajoutFacture , je fais ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    procedure TAjoutFactForm.FormShow(Sender: TObject);
    var nNumfact:variant;
    begin
      DM.tbFacture.Last;
      nNumfact:=DM.tbFactureNUMFACT.Value + 1;
      Edit_numfact.Text:=IntToStr(nNumfact);
    end;
    ici je place la table Facture à la fin et j'incremente le numero de +1;
    ensuite ici , je fais une verification avant d'encoder la facture dans la table ;
    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
    procedure TAjoutFactForm.Button111Click(Sender: TObject);
    var resultat :variant;
    begin
      resultat:=DM.tbFacture.Locate('NUMFACT',StrToInt(Edit_numfact.Text),[]);
      if resultat then
      begin
        MessageDlg('        Ce numéro existe déjà !!!        ',
        mtInformation,[mbOk],0);
        Edit_numfact.Text:=InttoStr(DM.tbFactureNUMFACT.Value + 1);
        Edit_numfact.SetFocus;
        exit;
      end;
      ..
    .....
    end;
    ici il regarde dans la table si ce numero existe , et s'il existe , il doit incrementer le dernier numero.
    mais helas , il regarde par rapport au nombre de facture du contact et non par rapport à la table.
    je ne sais pas comment regler cette situation .
    merci pour votre aide à tous.

  2. #2
    Modérateur
    Avatar de Rayek
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2005
    Messages
    5 235
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    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 235
    Points : 8 504
    Points
    8 504
    Par défaut
    Faire un système de Gestion de facture complexe avec des maitres/détails sur des TxxxTable, c'est courrir à la catastrophe (Avis personnel, même si c'est réalisable avec une bonne prise de tête).

    Il aurait été si simple de passer par une requete pour récupérer le dernier numéro de facture.

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Select Max(NumFact) from [Le nom de la table facture]

    Ayant développer pour la société où je bosse, leur système de facturation (Plus de 200 clients facturés en 15 mn avec génération des PDF, inscription dans une base de donénes , etc ...), j'ai du mal à m'imaginer travailler sur des TxxxTable et cela sans utiliser de requete.

    Le problème que tu rencontres et dû au fait que ton maitre/détail prend le dessus sur ton Last. Il va se positionner sur le dernier enregistrement en correspondance avec le contact et non pas le dernier enregistrement de la table.
    Soit, tu utilises un autre TxxTable connecté à la même table et tu fais ton last afin d'hypothétiquement récupérer le dernier numéro de facture (Pas sûr que cela soit le dernier).
    Soit tu peux faire une requete (voir celle plus haut) pour récupérer le dernier numéro, rajouter 1 et le mettre dans ton TEdit
    Modérateur Delphi

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 25/09/2006, 10h18
  2. [C#] [Oracle] Probleme avec une procedure stockée
    Par sronin1 dans le forum Accès aux données
    Réponses: 4
    Dernier message: 28/05/2004, 19h04
  3. Probleme avec une table vide
    Par king dans le forum Bases de données
    Réponses: 5
    Dernier message: 20/03/2004, 14h24
  4. au secour probleme avec une requete...
    Par soufiane59 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 26/09/2003, 10h28
  5. probleme avec une division par zéro
    Par jcharleszoxi dans le forum Langage SQL
    Réponses: 2
    Dernier message: 26/03/2003, 18h14

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