使用 IntraWeb (44) - 測試讀取 SqLite (三)



使用數據連接池(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;


效果圖:



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM