BSOne.SFC/Tocsg.Lib/VCL/SQLite3/EM.Old.SQLite3.pas

654 lines
34 KiB
Plaintext

unit EM.Old.SQLite3;
{
Simplified interface for SQLite.
Updated for Sqlite 3 by Tim Anderson (tim@itwriting.com)
Note: NOT COMPLETE for version 3, just minimal functionality
Adapted from file created by Pablo Pissanetzky (pablo@myhtpc.net)
which was based on SQLite.pas by Ben Hochstrasser (bhoc@surfeu.ch)
}
{$IFDEF FPC}
{$MODE DELPHI}
{$H+} (* use AnsiString *)
{$PACKENUM 4} (* use 4-byte enums *)
{$PACKRECORDS C} (* C/C++-compatible record packing *)
{$ELSE}
{$MINENUMSIZE 4} (* use 4-byte enums *)
{$ENDIF}
interface
const
{$IF Defined(MSWINDOWS)}
SQLiteDLL = 'sqlite3.dll';
{$ELSEIF Defined(DARWIN)}
SQLiteDLL = 'libsqlite3.dylib';
{$linklib libsqlite3}
{$ELSEIF Defined(UNIX)}
SQLiteDLL = 'sqlite3.so';
{$IFEND}
// Return values for sqlite3_exec() and sqlite3_step()
const
SQLITE_OK = 0; // Successful result
(* beginning-of-error-codes *)
SQLITE_ERROR = 1; // SQL error or missing database
SQLITE_INTERNAL = 2; // An internal logic error in SQLite
SQLITE_PERM = 3; // Access permission denied
SQLITE_ABORT = 4; // Callback routine requested an abort
SQLITE_BUSY = 5; // The database file is locked
SQLITE_LOCKED = 6; // A table in the database is locked
SQLITE_NOMEM = 7; // A malloc() failed
SQLITE_READONLY = 8; // Attempt to write a readonly database
SQLITE_INTERRUPT = 9; // Operation terminated by sqlite3_interrupt()
SQLITE_IOERR = 10; // Some kind of disk I/O error occurred
SQLITE_CORRUPT = 11; // The database disk image is malformed
SQLITE_NOTFOUND = 12; // (Internal Only) Table or record not found
SQLITE_FULL = 13; // Insertion failed because database is full
SQLITE_CANTOPEN = 14; // Unable to open the database file
SQLITE_PROTOCOL = 15; // Database lock protocol error
SQLITE_EMPTY = 16; // Database is empty
SQLITE_SCHEMA = 17; // The database schema changed
SQLITE_TOOBIG = 18; // Too much data for one row of a table
SQLITE_CONSTRAINT = 19; // Abort due to contraint violation
SQLITE_MISMATCH = 20; // Data type mismatch
SQLITE_MISUSE = 21; // Library used incorrectly
SQLITE_NOLFS = 22; // Uses OS features not supported on host
SQLITE_AUTH = 23; // Authorization denied
SQLITE_FORMAT = 24; // Auxiliary database format error
SQLITE_RANGE = 25; // 2nd parameter to sqlite3_bind out of range
SQLITE_NOTADB = 26; // File opened that is not a database file
SQLITE_ROW = 100; // sqlite3_step() has another row ready
SQLITE_DONE = 101; // sqlite3_step() has finished executing
SQLITE_INTEGER = 1;
SQLITE_FLOAT = 2;
SQLITE_TEXT = 3;
SQLITE_BLOB = 4;
SQLITE_NULL = 5;
SQLITE_UTF8 = 1;
SQLITE_UTF16 = 2;
SQLITE_UTF16BE = 3;
SQLITE_UTF16LE = 4;
SQLITE_ANY = 5;
SQLITE_STATIC {: TSQLite3Destructor} = Pointer(0);
SQLITE_TRANSIENT {: TSQLite3Destructor} = Pointer(-1);
type
TSQLiteDB = Pointer;
TSQLiteResult = ^PAnsiChar;
TSQLiteStmt = Pointer;
type
PPAnsiCharArray = ^TPAnsiCharArray;
TPAnsiCharArray = array[0 .. (MaxInt div SizeOf(PAnsiChar))-1] of PAnsiChar;
TSQLite3Destructor = procedure(Ptr: Pointer); cdecl;
type
TSQLiteExecCallback = function(UserData: Pointer; NumCols: Integer; ColValues:
PPAnsiCharArray; ColNames: PPAnsiCharArray): Integer; cdecl;
TSQLiteBusyHandlerCallback = function(UserData: Pointer; P2: Integer): Integer; cdecl;
//function prototype for define own collate
TCollateXCompare = function(UserData: Pointer; Buf1Len: Integer; Buf1: Pointer;
Buf2Len: Integer; Buf2: Pointer): Integer; cdecl;
TSQLite3_Open = function(filename: PAnsiChar; var db: TSQLiteDB): Integer; cdecl;
TSQLite3_Close = function(db: TSQLiteDB): Integer; cdecl;
TSQLite3_Exec = function(db: TSQLiteDB; SQLStatement: PAnsiChar; CallbackPtr: TSQLiteExecCallback; UserData: Pointer; var ErrMsg: PAnsiChar): Integer; cdecl;
TSQLite3_Version = function: PAnsiChar; cdecl;
TSQLite3_ErrMsg = function(db: TSQLiteDB): PAnsiChar; cdecl;
TSQLite3_ErrCode = function(db: TSQLiteDB): Integer; cdecl;
TSQlite3_Free = procedure(P: PAnsiChar); cdecl;
TSQLite3_GetTable = function(db: TSQLiteDB; SQLStatement: PAnsiChar; var ResultPtr: TSQLiteResult; var RowCount: Cardinal; var ColCount: Cardinal; var ErrMsg: PAnsiChar): Integer; cdecl;
TSQLite3_FreeTable = procedure(Table: TSQLiteResult); cdecl;
TSQLite3_Complete = function(P: PAnsiChar): Boolean; cdecl;
TSQLite3_LastInsertRowID = function(db: TSQLiteDB): Int64; cdecl;
TSQLite3_Interrupt = procedure(db: TSQLiteDB); cdecl;
TSQLite3_BusyHandler = procedure(db: TSQLiteDB; CallbackPtr: TSQLiteBusyHandlerCallback; UserData: Pointer); cdecl;
TSQLite3_BusyTimeout = procedure(db: TSQLiteDB; TimeOut: Integer); cdecl;
TSQLite3_Changes = function(db: TSQLiteDB): Integer; cdecl;
TSQLite3_TotalChanges = function(db: TSQLiteDB): Integer; cdecl;
TSQLite3_Prepare = function(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer; cdecl;
TSQLite3_Prepare_v2 = function(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer; cdecl;
TSQLite3_ColumnCount = function(hStmt: TSqliteStmt): Integer; cdecl;
TSQLite3_ColumnName = function(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar; cdecl;
TSQLite3_ColumnDeclType = function(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar; cdecl;
TSQLite3_Step = function(hStmt: TSqliteStmt): Integer; cdecl;
TSQLite3_DataCount = function(hStmt: TSqliteStmt): Integer; cdecl;
TSQLite3_ColumnBlob = function(hStmt: TSqliteStmt; ColNum: Integer): Pointer; cdecl;
TSQLite3_ColumnBytes = function(hStmt: TSqliteStmt; ColNum: Integer): Integer; cdecl;
TSQLite3_ColumnDouble = function(hStmt: TSqliteStmt; ColNum: Integer): Double; cdecl;
TSQLite3_ColumnInt = function(hStmt: TSqliteStmt; ColNum: Integer): Integer; cdecl;
TSQLite3_ColumnText = function(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar; cdecl;
TSQLite3_ColumnType = function(hStmt: TSqliteStmt; ColNum: Integer): Integer; cdecl;
TSQLite3_ColumnInt64 = function(hStmt: TSqliteStmt; ColNum: Integer): Int64; cdecl;
TSQLite3_Finalize = function(hStmt: TSqliteStmt): Integer; cdecl;
TSQLite3_Reset = function(hStmt: TSqliteStmt): Integer; cdecl;
Tsqlite3_bind_blob = function(hStmt: TSqliteStmt; ParamNum: Integer;
ptrData: Pointer; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer; cdecl;
Tsqlite3_bind_text = function(hStmt: TSqliteStmt; ParamNum: Integer;
Text: PAnsiChar; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer; cdecl;
Tsqlite3_bind_double = function(hStmt: TSqliteStmt; ParamNum: Integer; Data: Double): Integer; cdecl;
Tsqlite3_bind_int = function(hStmt: TSqLiteStmt; ParamNum: Integer; Data: Integer): Integer; cdecl;
Tsqlite3_bind_int64 = function(hStmt: TSqliteStmt; ParamNum: Integer; Data: int64): Integer; cdecl;
Tsqlite3_bind_null = function(hStmt: TSqliteStmt; ParamNum: Integer): Integer; cdecl;
Tsqlite3_bind_parameter_index = function(hStmt: TSqliteStmt; zName: PAnsiChar): Integer; cdecl;
Tsqlite3_enable_shared_cache = function(Value: Integer): Integer; cdecl;
//user collate definiton
TSQLite3_create_collation = function(db: TSQLiteDB; Name: PAnsiChar; eTextRep: Integer;
UserData: Pointer; xCompare: TCollateXCompare): Integer; cdecl;
//function SQLite3_Open(filename: PAnsiChar; var db: TSQLiteDB): Integer; cdecl; external SQLiteDLL name 'sqlite3_open';
//function SQLite3_Close(db: TSQLiteDB): Integer; cdecl; external SQLiteDLL name 'sqlite3_close';
//function SQLite3_Exec(db: TSQLiteDB; SQLStatement: PAnsiChar; CallbackPtr: TSQLiteExecCallback; UserData: Pointer; var ErrMsg: PAnsiChar): Integer; cdecl; external SQLiteDLL name 'sqlite3_exec';
//function SQLite3_Version(): PAnsiChar; cdecl; external SQLiteDLL name 'sqlite3_libversion';
//function SQLite3_ErrMsg(db: TSQLiteDB): PAnsiChar; cdecl; external SQLiteDLL name 'sqlite3_errmsg';
//function SQLite3_ErrCode(db: TSQLiteDB): Integer; cdecl; external SQLiteDLL name 'sqlite3_errcode';
//procedure SQlite3_Free(P: PAnsiChar); cdecl; external SQLiteDLL name 'sqlite3_free';
//function SQLite3_GetTable(db: TSQLiteDB; SQLStatement: PAnsiChar; var ResultPtr: TSQLiteResult; var RowCount: Cardinal; var ColCount: Cardinal; var ErrMsg: PAnsiChar): Integer; cdecl; external SQLiteDLL name 'sqlite3_get_table';
//procedure SQLite3_FreeTable(Table: TSQLiteResult); cdecl; external SQLiteDLL name 'sqlite3_free_table';
//function SQLite3_Complete(P: PAnsiChar): boolean; cdecl; external SQLiteDLL name 'sqlite3_complete';
//function SQLite3_LastInsertRowID(db: TSQLiteDB): int64; cdecl; external SQLiteDLL name 'sqlite3_last_insert_rowid';
//procedure SQLite3_Interrupt(db: TSQLiteDB); cdecl; external SQLiteDLL name 'sqlite3_interrupt';
//procedure SQLite3_BusyHandler(db: TSQLiteDB; CallbackPtr: TSQLiteBusyHandlerCallback; UserData: Pointer); cdecl; external SQLiteDLL name 'sqlite3_busy_handler';
//procedure SQLite3_BusyTimeout(db: TSQLiteDB; TimeOut: Integer); cdecl; external SQLiteDLL name 'sqlite3_busy_timeout';
//function SQLite3_Changes(db: TSQLiteDB): Integer; cdecl; external SQLiteDLL name 'sqlite3_changes';
//function SQLite3_TotalChanges(db: TSQLiteDB): Integer; cdecl; external SQLiteDLL name 'sqlite3_total_changes';
//function SQLite3_Prepare(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer; cdecl; external SQLiteDLL name 'sqlite3_prepare';
//function SQLite3_Prepare_v2(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer; cdecl; external SQLiteDLL name 'sqlite3_prepare_v2';
//function SQLite3_ColumnCount(hStmt: TSqliteStmt): Integer; cdecl; external SQLiteDLL name 'sqlite3_column_count';
//function SQLite3_ColumnName(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar; cdecl; external SQLiteDLL name 'sqlite3_column_name';
//function SQLite3_ColumnDeclType(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar; cdecl; external SQLiteDLL name 'sqlite3_column_decltype';
//function SQLite3_Step(hStmt: TSqliteStmt): Integer; cdecl; external SQLiteDLL name 'sqlite3_step';
//function SQLite3_DataCount(hStmt: TSqliteStmt): Integer; cdecl; external SQLiteDLL name 'sqlite3_data_count';
//
//function SQLite3_ColumnBlob(hStmt: TSqliteStmt; ColNum: Integer): Pointer; cdecl; external SQLiteDLL name 'sqlite3_column_blob';
//function SQLite3_ColumnBytes(hStmt: TSqliteStmt; ColNum: Integer): Integer; cdecl; external SQLiteDLL name 'sqlite3_column_bytes';
//function SQLite3_ColumnDouble(hStmt: TSqliteStmt; ColNum: Integer): Double; cdecl; external SQLiteDLL name 'sqlite3_column_double';
//function SQLite3_ColumnInt(hStmt: TSqliteStmt; ColNum: Integer): Integer; cdecl; external SQLiteDLL name 'sqlite3_column_int';
//function SQLite3_ColumnText(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar; cdecl; external SQLiteDLL name 'sqlite3_column_text';
//function SQLite3_ColumnType(hStmt: TSqliteStmt; ColNum: Integer): Integer; cdecl; external SQLiteDLL name 'sqlite3_column_type';
//function SQLite3_ColumnInt64(hStmt: TSqliteStmt; ColNum: Integer): Int64; cdecl; external SQLiteDLL name 'sqlite3_column_int64';
//function SQLite3_Finalize(hStmt: TSqliteStmt): Integer; cdecl; external SQLiteDLL name 'sqlite3_finalize';
//function SQLite3_Reset(hStmt: TSqliteStmt): Integer; cdecl; external SQLiteDLL name 'sqlite3_reset';
function SQLite3_Open(filename: PAnsiChar; var db: TSQLiteDB): Integer;
function SQLite3_Close(db: TSQLiteDB): Integer;
function SQLite3_Exec(db: TSQLiteDB; SQLStatement: PAnsiChar; CallbackPtr: TSQLiteExecCallback; UserData: Pointer; var ErrMsg: PAnsiChar): Integer;
function SQLite3_Version: PAnsiChar;
function SQLite3_ErrMsg(db: TSQLiteDB): PAnsiChar;
function SQLite3_ErrCode(db: TSQLiteDB): Integer;
procedure SQlite3_Free(P: PAnsiChar);
function SQLite3_GetTable(db: TSQLiteDB; SQLStatement: PAnsiChar; var ResultPtr: TSQLiteResult; var RowCount: Cardinal; var ColCount: Cardinal; var ErrMsg: PAnsiChar): Integer;
procedure SQLite3_FreeTable(Table: TSQLiteResult);
function SQLite3_Complete(P: PAnsiChar): boolean;
function SQLite3_LastInsertRowID(db: TSQLiteDB): int64;
procedure SQLite3_Interrupt(db: TSQLiteDB);
procedure SQLite3_BusyHandler(db: TSQLiteDB; CallbackPtr: TSQLiteBusyHandlerCallback; UserData: Pointer);
procedure SQLite3_BusyTimeout(db: TSQLiteDB; TimeOut: Integer);
function SQLite3_Changes(db: TSQLiteDB): Integer;
function SQLite3_TotalChanges(db: TSQLiteDB): Integer;
function SQLite3_Prepare(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer;
function SQLite3_Prepare_v2(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer;
function SQLite3_ColumnCount(hStmt: TSqliteStmt): Integer;
function SQLite3_ColumnName(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar;
function SQLite3_ColumnDeclType(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar;
function SQLite3_Step(hStmt: TSqliteStmt): Integer;
function SQLite3_DataCount(hStmt: TSqliteStmt): Integer;
function SQLite3_ColumnBlob(hStmt: TSqliteStmt; ColNum: Integer): Pointer;
function SQLite3_ColumnBytes(hStmt: TSqliteStmt; ColNum: Integer): Integer;
function SQLite3_ColumnDouble(hStmt: TSqliteStmt; ColNum: Integer): Double;
function SQLite3_ColumnInt(hStmt: TSqliteStmt; ColNum: Integer): Integer;
function SQLite3_ColumnText(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar;
function SQLite3_ColumnType(hStmt: TSqliteStmt; ColNum: Integer): Integer;
function SQLite3_ColumnInt64(hStmt: TSqliteStmt; ColNum: Integer): Int64;
function SQLite3_Finalize(hStmt: TSqliteStmt): Integer;
function SQLite3_Reset(hStmt: TSqliteStmt): Integer;
//
// In the SQL strings input to sqlite3_prepare() and sqlite3_prepare16(),
// one or more literals can be replace by a wildcard "?" or ":N:" where
// N is an Integer. These value of these wildcard literals can be set
// using the routines listed below.
//
// In every case, the first parameter is a Pointer to the sqlite3_stmt
// structure returned from sqlite3_prepare(). The second parameter is the
// index of the wildcard. The first "?" has an index of 1. ":N:" wildcards
// use the index N.
//
// The fifth parameter to sqlite3_bind_blob(), sqlite3_bind_text(), and
//sqlite3_bind_text16() is a destructor used to dispose of the BLOB or
//text after SQLite has finished with it. If the fifth argument is the
// special value SQLITE_STATIC, then the library assumes that the information
// is in static, unmanaged space and does not need to be freed. If the
// fifth argument has the value SQLITE_TRANSIENT, then SQLite makes its
// own private copy of the data.
//
// The sqlite3_bind_* routine must be called before sqlite3_step() after
// an sqlite3_prepare() or sqlite3_reset(). Unbound wildcards are interpreted
// as NULL.
//
//function sqlite3_bind_blob(hStmt: TSqliteStmt; ParamNum: Integer;
// ptrData: Pointer; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer;
//cdecl; external SQLiteDLL name 'sqlite3_bind_blob';
//function sqlite3_bind_text(hStmt: TSqliteStmt; ParamNum: Integer;
// Text: PAnsiChar; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer;
//cdecl; external SQLiteDLL name 'sqlite3_bind_text';
//function sqlite3_bind_double(hStmt: TSqliteStmt; ParamNum: Integer; Data: Double): Integer;
// cdecl; external SQLiteDLL name 'sqlite3_bind_double';
//function sqlite3_bind_int(hStmt: TSqLiteStmt; ParamNum: Integer; Data: Integer): Integer;
// cdecl; external SQLiteDLL name 'sqlite3_bind_int';
//function sqlite3_bind_int64(hStmt: TSqliteStmt; ParamNum: Integer; Data: int64): Integer;
// cdecl; external SQLiteDLL name 'sqlite3_bind_int64';
//function sqlite3_bind_null(hStmt: TSqliteStmt; ParamNum: Integer): Integer;
// cdecl; external SQLiteDLL name 'sqlite3_bind_null';
//
//function sqlite3_bind_parameter_index(hStmt: TSqliteStmt; zName: PAnsiChar): Integer;
// cdecl; external SQLiteDLL name 'sqlite3_bind_parameter_index';
//
//function sqlite3_enable_shared_cache(Value: Integer): Integer; cdecl; external SQLiteDLL name 'sqlite3_enable_shared_cache';
//
////user collate definiton
//function SQLite3_create_collation(db: TSQLiteDB; Name: PAnsiChar; eTextRep: Integer;
// UserData: Pointer; xCompare: TCollateXCompare): Integer; cdecl; external SQLiteDLL name 'sqlite3_create_collation';
function sqlite3_bind_blob(hStmt: TSqliteStmt; ParamNum: Integer;
ptrData: Pointer; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer;
function sqlite3_bind_text(hStmt: TSqliteStmt; ParamNum: Integer;
Text: PAnsiChar; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer;
function sqlite3_bind_double(hStmt: TSqliteStmt; ParamNum: Integer; Data: Double): Integer;
function sqlite3_bind_int(hStmt: TSqLiteStmt; ParamNum: Integer; Data: Integer): Integer;
function sqlite3_bind_int64(hStmt: TSqliteStmt; ParamNum: Integer; Data: int64): Integer;
function sqlite3_bind_null(hStmt: TSqliteStmt; ParamNum: Integer): Integer;
function sqlite3_bind_parameter_index(hStmt: TSqliteStmt; zName: PAnsiChar): Integer;
function sqlite3_enable_shared_cache(Value: Integer): Integer;
//user collate definiton
function SQLite3_create_collation(db: TSQLiteDB; Name: PAnsiChar; eTextRep: Integer;
UserData: Pointer; xCompare: TCollateXCompare): Integer;
function SQLiteFieldType(SQLiteFieldTypeCode: Integer): AnsiString;
function SQLiteErrorStr(SQLiteErrorCode: Integer): AnsiString;
implementation
uses
SysUtils, Winapi.Windows;
var
_hSql3: THandle = 0;
_SQLite3_Open: TSQLite3_Open = nil;
_SQLite3_Close: TSQLite3_Close = nil;
_SQLite3_Exec: TSQLite3_Exec = nil;
_SQLite3_Version: TSQLite3_Version = nil;
_SQLite3_ErrMsg: TSQLite3_ErrMsg = nil;
_SQLite3_ErrCode: TSQLite3_ErrCode = nil;
_SQlite3_Free: TSQlite3_Free = nil;
_SQLite3_GetTable: TSQLite3_GetTable = nil;
_SQLite3_FreeTable: TSQLite3_FreeTable = nil;
_SQLite3_Complete: TSQLite3_Complete = nil;
_SQLite3_LastInsertRowID: TSQLite3_LastInsertRowID = nil;
_SQLite3_Interrupt: TSQLite3_Interrupt = nil;
_SQLite3_BusyHandler: TSQLite3_BusyHandler = nil;
_SQLite3_BusyTimeout: TSQLite3_BusyTimeout = nil;
_SQLite3_Changes: TSQLite3_Changes = nil;
_SQLite3_TotalChanges: TSQLite3_TotalChanges = nil;
_SQLite3_Prepare: TSQLite3_Prepare = nil;
_SQLite3_Prepare_v2: TSQLite3_Prepare_v2 = nil;
_SQLite3_ColumnCount: TSQLite3_ColumnCount = nil;
_SQLite3_ColumnName: TSQLite3_ColumnName = nil;
_SQLite3_ColumnDeclType: TSQLite3_ColumnDeclType = nil;
_SQLite3_Step: TSQLite3_Step = nil;
_SQLite3_DataCount: TSQLite3_DataCount = nil;
_SQLite3_ColumnBlob: TSQLite3_ColumnBlob = nil;
_SQLite3_ColumnBytes: TSQLite3_ColumnBytes = nil;
_SQLite3_ColumnDouble: TSQLite3_ColumnDouble = nil;
_SQLite3_ColumnInt: TSQLite3_ColumnInt = nil;
_SQLite3_ColumnText: TSQLite3_ColumnText = nil;
_SQLite3_ColumnType: TSQLite3_ColumnType = nil;
_SQLite3_ColumnInt64: TSQLite3_ColumnInt64 = nil;
_SQLite3_Finalize: TSQLite3_Finalize = nil;
_SQLite3_Reset: TSQLite3_Reset = nil;
_sqlite3_bind_blob: Tsqlite3_bind_blob = nil;
_sqlite3_bind_text: Tsqlite3_bind_text = nil;
_sqlite3_bind_double: Tsqlite3_bind_double = nil;
_sqlite3_bind_int: Tsqlite3_bind_int = nil;
_sqlite3_bind_int64: Tsqlite3_bind_int64 = nil;
_sqlite3_bind_null: Tsqlite3_bind_null = nil;
_sqlite3_bind_parameter_index: Tsqlite3_bind_parameter_index = nil;
_sqlite3_enable_shared_cache: Tsqlite3_enable_shared_cache = nil;
_SQLite3_create_collation: TSQLite3_create_collation = nil;
function InitSqlite3Procedure: Boolean;
begin
if _hSql3 = 0 then
begin
_hSql3 := SafeLoadLibrary(SQLiteDLL);
if _hSql3 <> 0 then
begin
@_SQLite3_Open := GetProcAddress(_hSql3, 'sqlite3_open');
@_SQLite3_Close := GetProcAddress(_hSql3, 'sqlite3_close');
@_SQLite3_Exec := GetProcAddress(_hSql3, 'sqlite3_exec');
@_SQLite3_Version := GetProcAddress(_hSql3, 'sqlite3_libversion');
@_SQLite3_ErrMsg := GetProcAddress(_hSql3, 'sqlite3_errmsg');
@_SQLite3_ErrCode := GetProcAddress(_hSql3, 'sqlite3_errcode');
@_SQlite3_Free := GetProcAddress(_hSql3, 'sqlite3_free');
@_SQLite3_GetTable := GetProcAddress(_hSql3, 'sqlite3_get_table');
@_SQLite3_FreeTable := GetProcAddress(_hSql3, 'sqlite3_free_table');
@_SQLite3_Complete := GetProcAddress(_hSql3, 'sqlite3_complete');
@_SQLite3_LastInsertRowID := GetProcAddress(_hSql3, 'sqlite3_last_insert_rowid');
@_SQLite3_Interrupt := GetProcAddress(_hSql3, 'sqlite3_interrupt');
@_SQLite3_BusyHandler := GetProcAddress(_hSql3, 'sqlite3_busy_handler');
@_SQLite3_BusyTimeout := GetProcAddress(_hSql3, 'sqlite3_busy_timeout');
@_SQLite3_Changes := GetProcAddress(_hSql3, 'sqlite3_changes');
@_SQLite3_TotalChanges := GetProcAddress(_hSql3, 'sqlite3_total_changes');
@_SQLite3_Prepare := GetProcAddress(_hSql3, 'sqlite3_prepare');
@_SQLite3_Prepare_v2 := GetProcAddress(_hSql3, 'sqlite3_prepare_v2');
@_SQLite3_ColumnCount := GetProcAddress(_hSql3, 'sqlite3_column_count');
@_SQLite3_ColumnName := GetProcAddress(_hSql3, 'sqlite3_column_name');
@_SQLite3_ColumnDeclType := GetProcAddress(_hSql3, 'sqlite3_column_decltype');
@_SQLite3_Step := GetProcAddress(_hSql3, 'sqlite3_step');
@_SQLite3_DataCount := GetProcAddress(_hSql3, 'sqlite3_data_count');
@_SQLite3_ColumnBlob := GetProcAddress(_hSql3, 'sqlite3_column_blob');
@_SQLite3_ColumnBytes := GetProcAddress(_hSql3, 'sqlite3_column_bytes');
@_SQLite3_ColumnDouble := GetProcAddress(_hSql3, 'sqlite3_column_double');
@_SQLite3_ColumnInt := GetProcAddress(_hSql3, 'sqlite3_column_int');
@_SQLite3_ColumnText := GetProcAddress(_hSql3, 'sqlite3_column_text');
@_SQLite3_ColumnType := GetProcAddress(_hSql3, 'sqlite3_column_type');
@_SQLite3_ColumnInt64 := GetProcAddress(_hSql3, 'sqlite3_column_int64');
@_SQLite3_Finalize := GetProcAddress(_hSql3, 'sqlite3_finalize');
@_SQLite3_Reset := GetProcAddress(_hSql3, 'sqlite3_reset');
@_sqlite3_bind_blob := GetProcAddress(_hSql3, 'sqlite3_bind_blob');
@_sqlite3_bind_text := GetProcAddress(_hSql3, 'sqlite3_bind_text');
@_sqlite3_bind_double := GetProcAddress(_hSql3, 'sqlite3_bind_double');
@_sqlite3_bind_int := GetProcAddress(_hSql3, 'sqlite3_bind_int');
@_sqlite3_bind_int64 := GetProcAddress(_hSql3, 'sqlite3_bind_int64');
@_sqlite3_bind_null := GetProcAddress(_hSql3, 'sqlite3_bind_null');
@_sqlite3_bind_parameter_index := GetProcAddress(_hSql3, 'sqlite3_bind_parameter_index');
@_sqlite3_enable_shared_cache := GetProcAddress(_hSql3, 'sqlite3_enable_shared_cache');
@_SQLite3_create_collation := GetProcAddress(_hSql3, 'sqlite3_create_collation');
end;
end;
Result := _hSql3 <> 0;
end;
function SQLite3_Open(filename: PAnsiChar; var db: TSQLiteDB): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Open) then
Result := _SQLite3_Open(filename, db);
end;
function SQLite3_Close(db: TSQLiteDB): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Close) then
Result := _SQLite3_Close(db);
end;
function SQLite3_Exec(db: TSQLiteDB; SQLStatement: PAnsiChar; CallbackPtr: TSQLiteExecCallback; UserData: Pointer; var ErrMsg: PAnsiChar): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Exec) then
Result := _SQLite3_Exec(db, SQLStatement, CallbackPtr, UserData, ErrMsg);
end;
function SQLite3_Version: PAnsiChar;
begin
if InitSqlite3Procedure and Assigned(_SQLite3_Version) then
_SQLite3_Version;
end;
function SQLite3_ErrMsg(db: TSQLiteDB): PAnsiChar;
begin
if InitSqlite3Procedure and Assigned(_SQLite3_ErrMsg) then
_SQLite3_ErrMsg(db);
end;
function SQLite3_ErrCode(db: TSQLiteDB): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_ErrCode) then
Result := _SQLite3_ErrCode(db);
end;
procedure SQlite3_Free(P: PAnsiChar);
begin
if InitSqlite3Procedure and Assigned(_SQlite3_Free) then
_SQlite3_Free(P);
end;
function SQLite3_GetTable(db: TSQLiteDB; SQLStatement: PAnsiChar; var ResultPtr: TSQLiteResult; var RowCount: Cardinal; var ColCount: Cardinal; var ErrMsg: PAnsiChar): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_GetTable) then
Result := _SQLite3_GetTable(db, SQLStatement, ResultPtr, RowCount, ColCount, ErrMsg);
end;
procedure SQLite3_FreeTable(Table: TSQLiteResult);
begin
if InitSqlite3Procedure and Assigned(_SQLite3_FreeTable) then
_SQLite3_FreeTable(Table);
end;
function SQLite3_Complete(P: PAnsiChar): boolean;
begin
if InitSqlite3Procedure and Assigned(_SQLite3_Complete) then
Result := _SQLite3_Complete(P);
end;
function SQLite3_LastInsertRowID(db: TSQLiteDB): Int64;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_LastInsertRowID) then
Result := _SQLite3_LastInsertRowID(db);
end;
procedure SQLite3_Interrupt(db: TSQLiteDB);
begin
if InitSqlite3Procedure and Assigned(_SQLite3_Interrupt) then
_SQLite3_Interrupt(db);
end;
procedure SQLite3_BusyHandler(db: TSQLiteDB; CallbackPtr: TSQLiteBusyHandlerCallback; UserData: Pointer);
begin
if InitSqlite3Procedure and Assigned(_SQLite3_BusyHandler) then
_SQLite3_BusyHandler(db, CallbackPtr, UserData);
end;
procedure SQLite3_BusyTimeout(db: TSQLiteDB; TimeOut: Integer);
begin
if InitSqlite3Procedure and Assigned(_SQLite3_BusyTimeout) then
_SQLite3_BusyTimeout(db, TimeOut);
end;
function SQLite3_Changes(db: TSQLiteDB): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Changes) then
Result := _SQLite3_Changes(db);
end;
function SQLite3_TotalChanges(db: TSQLiteDB): Integer;
begin
if InitSqlite3Procedure and Assigned(_SQLite3_TotalChanges) then
Result := _SQLite3_TotalChanges(db);
end;
function SQLite3_Prepare(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Prepare) then
Result := _SQLite3_Prepare(db, SQLStatement, nBytes, hStmt, pzTail);
end;
function SQLite3_Prepare_v2(db: TSQLiteDB; SQLStatement: PAnsiChar; nBytes: Integer; var hStmt: TSqliteStmt; var pzTail: PAnsiChar): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Prepare_v2) then
Result := _SQLite3_Prepare_v2(db, SQLStatement, nBytes, hStmt, pzTail);
end;
function SQLite3_ColumnCount(hStmt: TSqliteStmt): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnCount) then
Result := _SQLite3_ColumnCount(hStmt);
end;
function SQLite3_ColumnName(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar;
begin
Result := nil;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnName) then
Result := _SQLite3_ColumnName(hStmt, ColNum);
end;
function SQLite3_ColumnDeclType(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar;
begin
Result := nil;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnDeclType) then
Result := _SQLite3_ColumnDeclType(hStmt, ColNum);
end;
function SQLite3_Step(hStmt: TSqliteStmt): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Step) then
Result := _SQLite3_Step(hStmt);
end;
function SQLite3_DataCount(hStmt: TSqliteStmt): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_DataCount) then
Result := _SQLite3_DataCount(hStmt);
end;
function SQLite3_ColumnBlob(hStmt: TSqliteStmt; ColNum: Integer): Pointer;
begin
Result := nil;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnBlob) then
Result := _SQLite3_ColumnBlob(hStmt, ColNum);
end;
function SQLite3_ColumnBytes(hStmt: TSqliteStmt; ColNum: Integer): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnBytes) then
Result := _SQLite3_ColumnBytes(hStmt, ColNum);
end;
function SQLite3_ColumnDouble(hStmt: TSqliteStmt; ColNum: Integer): Double;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnDouble) then
Result := _SQLite3_ColumnDouble(hStmt, ColNum);
end;
function SQLite3_ColumnInt(hStmt: TSqliteStmt; ColNum: Integer): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnInt) then
Result := _SQLite3_ColumnInt(hStmt, ColNum);
end;
function SQLite3_ColumnText(hStmt: TSqliteStmt; ColNum: Integer): PAnsiChar;
begin
Result := nil;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnText) then
Result := _SQLite3_ColumnText(hStmt, ColNum);
end;
function SQLite3_ColumnType(hStmt: TSqliteStmt; ColNum: Integer): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnType) then
Result := _SQLite3_ColumnType(hStmt, ColNum);
end;
function SQLite3_ColumnInt64(hStmt: TSqliteStmt; ColNum: Integer): Int64;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_ColumnInt64) then
Result := _SQLite3_ColumnInt64(hStmt, ColNum);
end;
function SQLite3_Finalize(hStmt: TSqliteStmt): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Finalize) then
Result := _SQLite3_Finalize(hStmt);
end;
function SQLite3_Reset(hStmt: TSqliteStmt): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_Reset) then
Result := _SQLite3_Reset(hStmt);
end;
function sqlite3_bind_blob(hStmt: TSqliteStmt; ParamNum: Integer;
ptrData: Pointer; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_bind_blob) then
Result := _sqlite3_bind_blob(hStmt, ParamNum, ptrData, numBytes, ptrDestructor);
end;
function sqlite3_bind_text(hStmt: TSqliteStmt; ParamNum: Integer;
Text: PAnsiChar; numBytes: Integer; ptrDestructor: TSQLite3Destructor): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_bind_text) then
Result := _sqlite3_bind_text(hStmt, ParamNum, Text, numBytes, ptrDestructor);
end;
function sqlite3_bind_double(hStmt: TSqliteStmt; ParamNum: Integer; Data: Double): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_bind_double) then
Result := _sqlite3_bind_double(hStmt, ParamNum, Data);
end;
function sqlite3_bind_int(hStmt: TSqLiteStmt; ParamNum: Integer; Data: Integer): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_bind_int) then
Result := _sqlite3_bind_int(hStmt, ParamNum, Data);
end;
function sqlite3_bind_int64(hStmt: TSqliteStmt; ParamNum: Integer; Data: int64): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_bind_int64) then
Result := _sqlite3_bind_int64(hStmt, ParamNum, Data);
end;
function sqlite3_bind_null(hStmt: TSqliteStmt; ParamNum: Integer): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_bind_null) then
Result := _sqlite3_bind_null(hStmt, ParamNum);
end;
function sqlite3_bind_parameter_index(hStmt: TSqliteStmt; zName: PAnsiChar): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_bind_parameter_index) then
Result := _sqlite3_bind_parameter_index(hStmt, zName);
end;
function sqlite3_enable_shared_cache(Value: Integer): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_sqlite3_enable_shared_cache) then
Result := _sqlite3_enable_shared_cache(Value);
end;
function SQLite3_create_collation(db: TSQLiteDB; Name: PAnsiChar; eTextRep: Integer;
UserData: Pointer; xCompare: TCollateXCompare): Integer;
begin
Result := -1;
if InitSqlite3Procedure and Assigned(_SQLite3_create_collation) then
Result := _SQLite3_create_collation(db, Name, eTextRep, UserData, xCompare);
end;
// -----------------------------------------------------------------------------
function SQLiteFieldType(SQLiteFieldTypeCode: Integer): AnsiString;
begin
case SQLiteFieldTypeCode of
SQLITE_INTEGER: Result := 'Integer';
SQLITE_FLOAT: Result := 'Float';
SQLITE_TEXT: Result := 'Text';
SQLITE_BLOB: Result := 'Blob';
SQLITE_NULL: Result := 'Null';
else
Result := AnsiString('Unknown SQLite Field Type Code "' + IntToStr(SQLiteFieldTypeCode) + '"');
end;
end;
function SQLiteErrorStr(SQLiteErrorCode: Integer): AnsiString;
begin
case SQLiteErrorCode of
SQLITE_OK: Result := 'Successful result';
SQLITE_ERROR: Result := 'SQL error or missing database';
SQLITE_INTERNAL: Result := 'An internal logic error in SQLite';
SQLITE_PERM: Result := 'Access permission denied';
SQLITE_ABORT: Result := 'Callback routine requested an abort';
SQLITE_BUSY: Result := 'The database file is locked';
SQLITE_LOCKED: Result := 'A table in the database is locked';
SQLITE_NOMEM: Result := 'A malloc() failed';
SQLITE_READONLY: Result := 'Attempt to write a readonly database';
SQLITE_INTERRUPT: Result := 'Operation terminated by sqlite3_interrupt()';
SQLITE_IOERR: Result := 'Some kind of disk I/O error occurred';
SQLITE_CORRUPT: Result := 'The database disk image is malformed';
SQLITE_NOTFOUND: Result := '(Internal Only) Table or record not found';
SQLITE_FULL: Result := 'Insertion failed because database is full';
SQLITE_CANTOPEN: Result := 'Unable to open the database file';
SQLITE_PROTOCOL: Result := 'Database lock protocol error';
SQLITE_EMPTY: Result := 'Database is empty';
SQLITE_SCHEMA: Result := 'The database schema changed';
SQLITE_TOOBIG: Result := 'Too much data for one row of a table';
SQLITE_CONSTRAINT: Result := 'Abort due to contraint violation';
SQLITE_MISMATCH: Result := 'Data type mismatch';
SQLITE_MISUSE: Result := 'Library used incorrectly';
SQLITE_NOLFS: Result := 'Uses OS features not supported on host';
SQLITE_AUTH: Result := 'Authorization denied';
SQLITE_FORMAT: Result := 'Auxiliary database format error';
SQLITE_RANGE: Result := '2nd parameter to sqlite3_bind out of range';
SQLITE_NOTADB: Result := 'File opened that is not a database file';
SQLITE_ROW: Result := 'sqlite3_step() has another row ready';
SQLITE_DONE: Result := 'sqlite3_step() has finished executing';
else
Result := AnsiString('Unknown SQLite Error Code "' + IntToStr(SQLiteErrorCode) + '"');
end;
end;
function ColValueToStr(Value: PAnsiChar): AnsiString;
begin
if (Value = nil) then
Result := 'NULL'
else
Result := Value;
end;
end.