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 :

Enregistrement d'un Integer


Sujet :

Bases de données Delphi

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    107
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 107
    Points : 53
    Points
    53
    Par défaut Enregistrement d'un Integer
    Bonjour,
    Sous D6, j'utilise une DBGrid qui pointe sur une DataBase.
    Lorsque je mets à jour ma DataBase, seul les champs texte sont mis à jour.
    Les champs Integer sont totalement ignorés...??????
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    begin
      if DBG1.SelectedRows.Count>0 then
        with DBG1.DataSource.DataSet do
          for i:=0 to DBG1.SelectedRows.Count-1 do
          begin
            GotoBookmark(pointer(DBG1.SelectedRows.Items[i]));
            Fields[0].Value := DPrenom.Text;
            Fields[1].Value := DNom.Text;
            ......
            Fields[7].Value := StrToInt(IndDpt.Caption);
          end;
    end;
    J'ai essayé en en utilisant Val, mais identique...
    Mon champs 9, dans la base est déclaré comme Integer.
    Merci

  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
    Citation Envoyé par gbuxo
    Bonjour,
    Sous D6, j'utilise une DBGrid qui pointe sur une DataBase.
    Lorsque je mets à jour ma DataBase, seul les champs texte sont mis à jour.
    Les champs Integer sont totalement ignorés...??????

    J'ai essayé en en utilisant Val, mais identique...
    Mon champs 9, dans la base est déclaré comme Integer.
    Merci
    1er remarque : Tu parles du champs "Numéro 9", seul problème c'est que dans ton code tu ne vas que jusqu'à 7, donc il te manque un champ à renseigner.(rappel que les champs vont de 0 à nombre -1 dans delphi)

    2em remarque : Tu ne mets pas en edition, ni ne valide les modifications de ton dataset, ce qui entraine qu'il risque ne pas y avoir certaine mise à jours des champs de faites.

    3em remarque : Je te conseil d'utiliser les noms des champs via un FieldByName() plutot que de passer par un Fields[] pour 2 raisons :
    • La lecture du code : Il est plus facile de lire FieldByName('NomClient').AsString que Fields[58].Value, de plus si quelqu'un passe derriere toi ou si tu dois dans longtemps revenir dans le code il te sera plus facile de le lire.
    • La modification de la base de données : Les bases de données ca evolue, les patrons demandent parfois de rajouter des fonctionnalités à un programme, etc ..., ce qui entrain souvent l'ajout/deplacement de champs. Avec un Fields[x] si tu deplaces un champ de position ou que tu rajoutes en champ en plein milieu tu vas être obliger de modifier tous ton code, alors qu'avec un FieldByName() tu n'as pas besoin de la faire car il n'a pas besoin de connaitre la position du champ dans la base de données.


    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
    begin
      if DBG1.SelectedRows.Count>0 then
        with DBG1.DataSource.DataSet do
          for i:=0 to DBG1.SelectedRows.Count-1 do
          begin
            GotoBookmark(pointer(DBG1.SelectedRows.Items[i]));
            edit; // met le dataset en mode éditon
            Fields[0].Value := DPrenom.Text;
            Fields[1].Value := DNom.Text;
            ......
            Fields[7].Value := StrToInt(IndDpt.Caption);
            Post; // Valide les modifications
          end;
    end;
    Modérateur Delphi

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

  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 771
    Points
    2 771
    Par défaut
    pour moi j'ai pas compris ce que tu veux faire exactement, tu mis a jour ta base avec les meme valeur!!!??
    PAS DE DESTIN, C'EST CE QUE NOUS FAISONS

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Mai 2002
    Messages
    107
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2002
    Messages : 107
    Points : 53
    Points
    53
    Par défaut
    Bonjour,
    Exact, j'avais oublié Edit et Post....
    Je reviens à Delphi après quelques années d'égarement, il faut que je retrouve mes marques.
    Merci

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

Discussions similaires

  1. Filtrage des enregistrements de type integer
    Par unja2010 dans le forum Bases de données
    Réponses: 2
    Dernier message: 25/06/2013, 00h06
  2. [VB6] [Crystal] Selection enregistrement
    Par littlecow dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 11/01/2005, 13h08
  3. Enregistrer un RichEdit dans un .Txt
    Par Clément[Delphi] dans le forum Composants VCL
    Réponses: 2
    Dernier message: 06/08/2002, 11h52
  4. [BDD] Enregistrer le résultat d'une requête
    Par Mowgly dans le forum C++Builder
    Réponses: 5
    Dernier message: 19/06/2002, 15h26
  5. enregistrer dans un fichier avec une appli mdi
    Par ferrari dans le forum C++Builder
    Réponses: 4
    Dernier message: 05/05/2002, 15h17

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