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 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
| unit TestForum_u1;
interface
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.DBCtrls, Vcl.Grids, Vcl.DBGrids, Data.DB,
// FireDAC ou un autre, peu importe
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.IB,
FireDAC.Phys.IBDef, FireDAC.VCLUI.Wait, FireDAC.Comp.Client,
FireDAC.Stan.Param, FireDAC.DatS, FireDAC.DApt.Intf, FireDAC.DApt,
FireDAC.Comp.DataSet;
type
TForm2 = class(TForm)
MyDB: TFDConnection;
tbSPECIALITE: TFDTable;
tbSECTION: TFDTable;
tbSTAGIAIRE: TFDTable;
dsSPECIALITE: TDataSource;
dsSECTION: TDataSource;
dsSTAGIAIRE: TDataSource;
cbSPECIALITE: TDBLookupComboBox;
grSTAGIAIRE: TDBGrid;
grSECTION: TDBGrid;
procedure FormCreate(Sender: TObject);
private
{ Déclarations privées }
public
{ Déclarations publiques }
end;
var
Form2: TForm2;
implementation
{$R *.dfm}
procedure TForm2.FormCreate(Sender: TObject);
begin
{ Toutes les propriétés ci-dessous peuvent être renseignées en mode conception via l'EDI}
MyDb.Connected := true;
tbSPECIALITE.Connection := MyDB;
tbSPECIALITE.IndexFieldNames := 'SPECOD'; // l'index doit exister sur le code specialité
tbSPECIALITE.Open;
dsSPECIALITE.DataSet := tbSPECIALITE;
with cbSPECIALITE do
begin
ListSource := dsSPECIALITE;
ListField := 'SPENOM;SPECOD';
KeyField := 'SPENOM';
// Keyvalue: pour affichage au démarrage du prog, avant la 1er click
Keyvalue := tbSPECIALITE.Fieldvalues['SPENOM'];
end;
tbSECTION.Connection := MyDb;
tbSECTION.IndexFieldNames := 'SPECOD;SECCOD'; // l'index doit exister sur les champs
tbSECTION.MasterSource := dsSPECIALITE;
tbSECTION.MasterFields := 'SPECOD';
dsSECTION.DataSet := tbSECTION;
grSECTION.DataSource := dsSECTION;
tbSECTION.Open;
tbSTAGIAIRE.Connection := MyDb;
tbSTAGIAIRE.IndexFieldNames := 'SECCOD;STANOM'; // l'index doit exister ...
tbSTAGIAIRE.MasterSource := dsSECTION;
tbSTAGIAIRE.MasterFields := 'SECCOD';
tbSTAGIAIRE.Open;
dsSTAGIAIRE.DataSet := tbSTAGIAIRE;
grSTAGIAIRE.DataSource := dsSTAGIAIRE;
end;
end. |
Partager