File: sqliteform.pas

package info (click to toggle)
lazarus 2.0.0%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 214,460 kB
  • sloc: pascal: 1,862,622; xml: 265,709; cpp: 56,595; sh: 3,008; java: 609; makefile: 535; perl: 297; sql: 222; ansic: 137
file content (92 lines) | stat: -rw-r--r-- 2,110 bytes parent folder | download | duplicates (10)
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
unit sqliteform;

{$mode objfpc}{$H+}

interface

uses
  Classes, SysUtils, db, FileUtil, Forms, Controls, Graphics, Dialogs, StdCtrls,
  DbCtrls
  {$ifdef CPUARM}
    ,sqlitejniandroid
  {$else}
    ,sqlite3ds
  {$endif}
  ;

type

  { TformSqlite }

  TformSqlite = class(TForm)
    btnConnect: TButton;
    btnSaveDB: TButton;
    btnCreateDB: TButton;
    Edit1: TEdit;
    SqliteDatasource: TDatasource;
    DBEdit1: TDBEdit;
    DBNavigator1: TDBNavigator;
    procedure btnCreateDBClick(Sender: TObject);
    procedure btnConnectClick(Sender: TObject);
    procedure btnSaveDBClick(Sender: TObject);
  private
    { private declarations }
  public
    { public declarations }
    sqlitedb: {$ifdef CPUARM}TSqliteJNIDataset;{$else}TSqlite3Dataset;{$endif}
  end;

var
  formSqlite: TformSqlite;

implementation

{$R *.lfm}

{ TformSqlite }

procedure TformSqlite.btnConnectClick(Sender: TObject);
begin
  {$ifdef CPUARM}
  sqlitedb := TSqliteJNIDataset.Create(Self);
  sqlitedb.FileName := '/sdcard/database.db';
  {$else}
  sqlitedb := TSqlite3Dataset.Create(Self);
  sqlitedb.FileName := 'database.db';
  {$endif}
  sqlitedb.TableName := 'TestTable';
  sqlitedb.FieldDefs.Add('FirstFieldStr', ftString);
  sqlitedb.FieldDefs.Add('SecondFieldInt', ftInteger);
  sqlitedb.SaveOnClose := True;
  sqlitedb.Open();
  SqliteDatasource.DataSet := sqlitedb;
end;

procedure TformSqlite.btnSaveDBClick(Sender: TObject);
begin
  if sqlitedb = nil then Exit;
  sqlitedb.Close();
  sqlitedb.Open();
end;

procedure TformSqlite.btnCreateDBClick(Sender: TObject);
var
  lsqlitedb: {$ifdef CPUARM}TSqliteJNIDataset;{$else}TSqlite3Dataset;{$endif}
begin
  {$ifdef CPUARM}
  lsqlitedb := TSqliteJNIDataset.Create(Self);
  lsqlitedb.FileName := '/sdcard/database.db';
  {$else}
  lsqlitedb := TSqlite3Dataset.Create(Self);
  lsqlitedb.FileName := 'database.db';
  {$endif}
  //SqliteDatasource.DataSet := sqlitedb;
  lsqlitedb.TableName := 'TestTable';
  lsqlitedb.FieldDefs.Add('FirstFieldStr', ftString);
  lsqlitedb.FieldDefs.Add('SecondFieldInt', ftInteger);
  lsqlitedb.CreateTable();
  lsqlitedb.Free;
end;

end.