首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Delphi: SQLite和UniDac

Delphi: SQLite和UniDac
EN

Stack Overflow用户
提问于 2012-05-25 20:24:41
回答 1查看 4.1K关注 0票数 2

需要在SQLite中存储一些数据。要使用SQLite,选择了UniDac,但有一个问题:当在UniConnection中时,在“数据库”字段中,我选择SQLite并输入数据库的名称-得到错误“不支持的元数据种类”。未创建数据库文件。有什么问题吗?就像以前使用UniDac一样,这样的问题不会被观察到。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-05-30 09:55:46

使用Delphi XE2的UniDAC 4.1.6我没有看到任何问题。SQLite3.dll必须位于系统路径或与可执行文件相同的目录中。下面是一个非常基本的例子,当点击btnConnect时会创建数据文件。

代码语言:javascript
复制
unit uMain;

interface

uses
  Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
  Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.Grids, Vcl.DBGrids, UniProvider,
  SQLiteUniProvider, Data.DB, MemDS, DBAccess, Uni, Vcl.ExtCtrls, Vcl.DBCtrls,
  Vcl.StdCtrls;

type
  TfrmMain = class(TForm)
    UniDataSource1: TUniDataSource;
    UniConnection1: TUniConnection;
    UniQuery1: TUniQuery;
    SQLiteUniProvider1: TSQLiteUniProvider;
    DBGrid1: TDBGrid;
    edtDBName: TEdit;
    Label1: TLabel;
    DBNavigator1: TDBNavigator;
    btnConnect: TButton;
    procedure btnConnectClick(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;

var
  frmMain: TfrmMain;

implementation

{$R *.dfm}

procedure TfrmMain.btnConnectClick(Sender: TObject);
begin
  if (btnConnect.Caption = 'Connect') then
  begin
    UniConnection1.ProviderName := 'SQLite';
    UniConnection1.Database := ExtractFilePath(Application.ExeName)
     + edtDBName.Text;
    UniConnection1.Connect;
    btnConnect.Caption := 'Disconnect';
  end
  else
  begin
    UniConnection1.Disconnect;
    btnConnect.Caption := 'Connect';
  end;
end;
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/10754390

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档