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 :

Firedac - Sélection du libellé lié à 1 FK


Sujet :

Bases de données Delphi

  1. #1
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 903
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 903
    Points : 6 027
    Points
    6 027
    Par défaut Firedac - Sélection du libellé lié à 1 FK
    Bonjour,

    C'est certainement un cas d'école, mais je tourne en rond ...

    Dans 1 table j'ai un champ qui référence (FK) l'ID de la table "Pays".

    Cette table a 80 colonnes, et le formulaire d'ajout/modif s'étale sur 3 tabsheets (le dbgrid est exclu)

    • Quel type de combobox pour présenter à l'utilisateur la liste des pays en mode "ajout"? DBCombo ou DBLookUp?
    • En mode "browse" de la table, comment positionner, dans cette combo, le pays correspondant à la FK?
    • Comment assurer la mémorisation de l'ID du pays choisi? (en ajout/modif)


    Est-ce possible grâce au LiveBinding ? (et si oui, comment?)

    En vous remerciant par avance.
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

  2. #2
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 043
    Points : 40 957
    Points
    40 957
    Billets dans le blog
    62
    Par défaut
    Bonjour

    Utiliser DBLookupComboBox répondrait aux trois questions (j'ai toujours eu l'habitude, depuis D3 de l'utiliser)

    Est-ce possible grâce au LiveBinding ? (et si oui, comment?)
    Challenge intéressant sachant qu'il n'est pas possible de lier les données de deux tables, du moins visuellement.
    En apéritif un billet qui pourrait être la technique que j'utiliserai.

    Donc, en gros, on a le design suivant (avec mes jeux d'essais, Pays est devenu Appositions, mais le principe reste le même )
    Nom : Capture.PNG
Affichages : 130
Taille : 36,7 Ko

    Avec ce schéma voici le code que j'utiliserai
    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 TForm15.ComboBox1Change(Sender: TObject);
    begin
    if not (FDQModeles.State in [dsEdit,dsInsert]) then  FDQModeles.Edit;
     
    FDQModeles.FieldByName('APPOSE').AsString:=FDTAppose.FieldByName('CODE_APPOSE').AsString;
    FDQModeles.Post;
    FDQModeles.Refresh;
     
    end;
     
    procedure TForm15.FDQModelesAfterScroll(DataSet: TDataSet);
    begin
    if not FDTAppose.Active then FDTAppose.Active:=true;
     FDTAppose.Locate('CODE_APPOSE',FDQModeles.FieldByName('APPOSE').AsString,[]);
    end;
    mais ce n'est pas ce que j'appellerai une bonne utilisation de Livebindings, il ne devrait pas y avoir de code du tout

    Il faudrait que je regarde dans mes applications FMX, car j'ai certainement dû le faire, mais, ce matin, j'ai un trou de mémoire et pas sûr que ce soit applicable en VCL (avec un Combobox déjà)
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

  3. #3
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 903
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 903
    Points : 6 027
    Points
    6 027
    Par défaut
    Bonjour Serge, et merci pour tes explications.

    Citation Envoyé par SergioMaster Voir le message
    mais ce n'est pas ce que j'appellerai une bonne utilisation de Livebindings, il ne devrait pas y avoir de code du tout
    Ceci m'a mis la puce à l'oreille, et effectivement la solution peut se passer de code (et de livebinding ).

    En relisant la doc avec attention et avec quand même quelques essais infructueux, tout se passe dans le dbLookUpCombo.

    On y effectue une sorte de jointure (dans mon cas: personne||pays):

    Paramétrage de ce qui peut être affiché: les libellés de pays (COUNTRY_NAME)
    Nom : Capture.JPG
Affichages : 132
Taille : 16,5 Ko

    Paramétrage de ce qui doit être affiché: ("condition de jointure")
    Nom : Capture.JPG
Affichages : 132
Taille : 11,7 Ko

    Bien sûr, les 2 tables ont leur colonne COUNTRY_ID.

    C'est OK pour moi.
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

  4. #4
    Rédacteur/Modérateur

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

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

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 043
    Points : 40 957
    Points
    40 957
    Billets dans le blog
    62
    Par défaut
    En fait la réponse Livebindings était dans un de mes premiers tutoriels sur les LiveBindings

    et voilà
    Nom : Capture.PNG
Affichages : 131
Taille : 30,9 Ko

    no code
    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
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    unit MainU;
     
    interface
     
    uses
      Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
      Vcl.Controls, Vcl.Forms, Vcl.Dialogs, FireDAC.Stan.Intf, FireDAC.Stan.Option,
      FireDAC.Stan.Error, FireDAC.UI.Intf, FireDAC.Phys.Intf, FireDAC.Stan.Def,
      FireDAC.Stan.Pool, FireDAC.Stan.Async, FireDAC.Phys, FireDAC.Phys.FB,
      FireDAC.Phys.FBDef, FireDAC.VCLUI.Wait, FireDAC.Stan.Param, FireDAC.DatS,
      FireDAC.DApt.Intf, FireDAC.DApt, Data.Bind.EngExt, Vcl.Bind.DBEngExt,
      System.Rtti, System.Bindings.Outputs, Vcl.Bind.Editors, Vcl.Bind.Grid,
      Data.Bind.Controls, Data.Bind.Components, Vcl.StdCtrls, Vcl.ExtCtrls,
      Vcl.Buttons, Vcl.Bind.Navigator, FireDAC.Comp.Client, Data.Bind.Grid,
      Vcl.Grids, Data.Bind.DBScope, Data.DB, FireDAC.Comp.DataSet;
     
    type
      TForm15 = class(TForm)
        FDCFB: TFDConnection;
        FDQModeles: TFDQuery;
        FDTAppose: TFDTable;
        ComboBox1: TComboBox;
        BindSourceAppose: TBindSourceDB;
        BindingsList1: TBindingsList;
        BindSourceModeles: TBindSourceDB;
        StringGrid1: TStringGrid;
        LinkGridToDataSourceBindSourceDB2: TLinkGridToDataSource;
        Edit1: TEdit;
        LinkControlToField1: TLinkControlToField;
        FDUpdateModeles: TFDUpdateSQL;
        BindNavigator1: TBindNavigator;
        Label1: TLabel;
        Label2: TLabel;
        Label3: TLabel;
        Label4: TLabel;
        LinkFillControlToField: TLinkFillControlToField;
      private
        { Déclarations privées }
      public
        { Déclarations publiques }
      end;
     
    var
      Form15: TForm15;
     
    implementation
     
    {$R *.dfm}
     
    end.
    MVP Embarcadero
    Delphi installés : D3,D7,D2010,XE4,XE7,D10 (Rio, Sidney), D11 (Alexandria), D12 (Athènes)
    SGBD : Firebird 2.5, 3, SQLite
    générateurs États : FastReport, Rave, QuickReport
    OS : Window Vista, Windows 10, Windows 11, Ubuntu, Androïd

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

Discussions similaires

  1. [XL-365] Pb sélection 4 cellules correspondant à un libellé "E"
    Par jojo31500 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 02/03/2023, 10h26
  2. [CR] Problème de sélection sur un champ date
    Par noluc dans le forum SAP Crystal Reports
    Réponses: 2
    Dernier message: 21/11/2003, 16h56
  3. Sélection texte d'un TMemo
    Par nmathon dans le forum Composants VCL
    Réponses: 2
    Dernier message: 12/05/2003, 16h17
  4. Couleur de sélection par défaut
    Par sicard_51 dans le forum AWT/Swing
    Réponses: 2
    Dernier message: 20/04/2003, 23h35
  5. Déplacer la sélection d'une ligne dans un stringgrid
    Par jer64 dans le forum Composants VCL
    Réponses: 5
    Dernier message: 14/03/2003, 00h57

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