本文整理自网络,侵删。
为了方便测试, 我把官方提供的 C:\Users\Public\Documents\Embarcadero\Studio\14.0\Samples\data\FDDemo.sdb 复制了一份到 C:\Temp\FDDemo.sdb.
{新建一个 VCL Forms Application, 然后添加如下控件(建议按 Ctrl + . 后用键盘输入添加):}
TFDPhysSQLiteDriverLink // 用于驱动自动连接; 不同数据库各对应一个: TFDPhys****DriverLinkTFDGUIxWaitCursor // 用于自动管理 GUI 程序的"等待光标"; 在 Console 和 FMX 下也都有类似对应的东西TFDConnection // 数据连接TFDQuery // 数据查询TDataSource // 数据源TDBGrid // 数据显示
// uses FireDAC.Phys.SQLite 之后, 可不用添加 TFDPhysSQLiteDriverLink// uses FireDAC.VCLUI.Wait 之后, 可不用添加 TFDGUIxWaitCursor
{简单几行代码, 就呈现了 FDDemo.sdb 中的 Orders 表中的数据}procedure TForm1.FormCreate(Sender: TObject);begin FDConnection1.DriverName := 'SQLite'; FDConnection1.Params.Add('Database=C:\Temp\FDDemo.sdb');
FDQuery1.Connection := FDConnection1; DataSource1.DataSet := FDQuery1; DBGrid1.DataSource := DataSource1;
FDQuery1.SQL.Text := 'SELECT * FROM Orders'; // SQLite 非常好地支持了 SQL92 标准, 目前被忽略的仅有: http://www.sqlite.org/omitted.html
FDConnection1.Open(); FDQuery1.Open();
DBGrid1.Align := alClient;end;
效果图:{稍稍变通一下代码}procedure TForm1.FormCreate(Sender: TObject);begin// FDConnection1.ConnectionString := 'DriverID=SQLite; Database=C:\Temp\FDDemo.sdb'; // 可代替下面两行 FDConnection1.Params.Add('DriverID=SQLite'); // 同 FDConnection1.DriverName := 'SQLite'; FDConnection1.Params.Add('Database=C:\Temp\FDDemo.sdb');
FDQuery1.Connection := FDConnection1; DataSource1.DataSet := FDQuery1; DBGrid1.DataSource := DataSource1;
FDQuery1.SQL.Text := 'SELECT * FROM Orders';
FDConnection1.Connected := True; FDQuery1.Active := True;
DBGrid1.Align := alClient;end;
{再变通一下}procedure TForm1.FormCreate(Sender: TObject);begin FDQuery1.Connection := FDConnection1; DataSource1.DataSet := FDQuery1; DBGrid1.DataSource := DataSource1;
FDConnection1.Open('DriverID=SQLite;Database=C:\Temp\FDDemo.sdb'); FDQuery1.Open('SELECT * FROM Orders');
DBGrid1.Align := alClient;end;
相关阅读 >>
Delphi 判断时间是否合法 -isvaliddatetime、isvaliddate、isvalidtime、isvaliddateday
更多相关阅读请进入《Delphi》频道 >>