使用數據連接池(TIWDataModulePool).
新建工程時勾選 Pool Data Connections:

新增的 Pool(TIWDataModulePool) 被放在 ServerController 的窗體上(其實它也是個數據模塊), 需要知道的變化是它增加了兩個函數:
function LockDataModule: TDataModule1; procedure UnlockDataModule(ADataModule: TDataModule1);
同時 Wizard 還自動生成了一個專門的數據模塊 DataModuleUnit;
先把數據源相關控件放在 DataModuleUnit 的窗體上:
FDPhysSQLiteDriverLink1: TFDPhysSQLiteDriverLink; FDGUIxWaitCursor1: TFDGUIxWaitCursor; FDConnection1: TFDConnection; DataSource1: TDataSource; FDTable1: TFDTable;
然后在其 OnCreate 事件中寫代碼:
procedure TDataModule1.DataModuleCreate(Sender: TObject); begin FDTable1.Connection := FDConnection1; DataSource1.DataSet := FDTable1; FDConnection1.DriverName := 'SQLite'; FDConnection1.Params.Add('Database=FDDemo.sdb'); //別忘了把 FDDemo.sdb 復制到程序目錄下 FDTable1.TableName := 'Orders'; // FDTable1.Active := True; end;
最后回到主窗體, 先放個 IWDBGrid1: TIWDBGrid; 然后寫代碼:
uses DataModuleUnit, ServerController; procedure TIWForm1.IWAppFormCreate(Sender: TObject); var fDataModule: TDataModule1; begin fDataModule := LockDataModule; IWDBGrid1.DataSource := fDataModule.DataSource1; fDataModule.FDTable1.Active := True; UnlockDataModule(fDataModule); IWDBGrid1.Align := alClient; end;
效果圖:
