mirror of
https://gitlab.com/freepascal.org/fpc/source.git
synced 2025-05-01 21:53:44 +02:00
373 lines
13 KiB
ObjectPascal
373 lines
13 KiB
ObjectPascal
{ $Id$ }
|
||
|
||
unit mysql3;
|
||
|
||
{$undef use_mysql_321} { if undefined, use mysql 3.23 interface }
|
||
|
||
{
|
||
Import unit for the mysql header files.
|
||
|
||
Translated form the original mysql.h by Michael Van Canneyt
|
||
(michael@tfdec1.fys.kuleuven.ac.be)
|
||
|
||
updated to mysql version 3.23 header files by Bernhard Steffen
|
||
(bernhard.steffen@gmx.net)
|
||
}
|
||
{$r+,i+,o+}
|
||
|
||
interface
|
||
|
||
uses mysql3_com, mysql3_version;
|
||
{$ifdef win32}
|
||
Const mysqllib = 'libmysql';
|
||
{$else}
|
||
Const mysqllib = 'mysqlclient';
|
||
{$endif}
|
||
|
||
{$ifndef win32}
|
||
{$linklib c}
|
||
{$linklib m}
|
||
{$linklib mysqlclient}
|
||
{$endif}
|
||
|
||
{$packrecords C}
|
||
|
||
type
|
||
my_bool = byte;
|
||
gptr = pchar;
|
||
Socket = Longint;
|
||
PCardinal = ^Cardinal;
|
||
|
||
{$ifdef linux}
|
||
Var
|
||
mysql_port : cardinal; external name 'mysql_port';
|
||
mysql_unix_port : pchar; external name 'mysql_unix_port';
|
||
{$endif}
|
||
|
||
{$ifdef darwin}
|
||
Var
|
||
mysql_port : cardinal; external mysqllib name 'mysql_port';
|
||
mysql_unix_port : pchar; external mysqllib name 'mysql_unix_port';
|
||
{$endif}
|
||
|
||
{
|
||
#define IS_PRI_KEY(n) ((n) & PRI_KEY_FLAG)
|
||
#define IS_NOT_NULL(n) ((n) & NOT_NULL_FLAG)
|
||
#define IS_BLOB(n) ((n) & BLOB_FLAG)
|
||
#define IS_NUM(t) ((t) <= FIELD_TYPE_INT24)
|
||
}
|
||
Type
|
||
st_mysql_field = record
|
||
name : Pchar; { Name of column }
|
||
table : pchar; { Table of column if column was a field }
|
||
def: pchar; { Default value (set by mysql_list_fields) }
|
||
ftype : enum_field_types; { Type of field. See mysql_com.h for types }
|
||
length : cardinal; { Width of column }
|
||
max_length : cardinal; { Max width of selected set }
|
||
flags : cardinal; { Div flags }
|
||
decimals : cardinal; { Number of decimals in field }
|
||
end;
|
||
TMYSQL_FIELD = st_mysql_field;
|
||
PMYSQL_FIELD = ^TMYSQL_FIELD;
|
||
|
||
TMYSQL_ROW = PPchar; { return data as array of strings }
|
||
TMYSQL_FIELD_OFFSET = cardinal; { offset to current field }
|
||
|
||
{$ifndef oldmysql}
|
||
my_ulonglong=qword;
|
||
{$else}
|
||
my_longlong=cardinal;
|
||
{$endif}
|
||
|
||
PST_MYSQL_Rows = ^st_mysql_rows;
|
||
st_mysql_rows = Record
|
||
next : pst_mysql_rows; { list of rows }
|
||
Data : TMYSQL_ROW;
|
||
end;
|
||
TMYSQL_ROWS = st_mysql_rows;
|
||
PMYSQL_ROWS = ^TMYSQL_ROWS;
|
||
|
||
|
||
TMYSQL_ROW_OFFSET = PMYSQL_ROWS; { offset to current row }
|
||
|
||
st_mysql_data = record
|
||
rows : my_ulonglong;
|
||
fields : cardinal;
|
||
data : PMYSQL_ROWS;
|
||
alloc : TMEM_ROOT;
|
||
end;
|
||
|
||
TMYSQL_DATA = st_mysql_data;
|
||
PMYSQL_DATA = ^TMYSQL_DATA;
|
||
|
||
st_mysql_options = record
|
||
connect_timeout,client_flag : cardinal;
|
||
compress,named_pipe : my_bool;
|
||
port : cardinal;
|
||
host,init_command,user,password,unix_socket,db : pchar;
|
||
my_cnf_file,my_cnf_group : pchar;
|
||
{$ifndef use_mysql_321}
|
||
charset_dir, charset_name : pchar;
|
||
use_ssl : my_bool;
|
||
ssl_key, ssl_cert, ssl_ca, ssl_capath : pchar;
|
||
{$endif}
|
||
end;
|
||
|
||
{$ifndef use_mysql_321}
|
||
mysql_option = (MYSQL_OPT_CONNECT_TIMEOUT, MYSQL_OPT_COMPRESS,
|
||
MYSQL_OPT_NAMED_PIPE, MYSQL_INIT_COMMAND,
|
||
MYSQL_READ_DEFAULT_FILE, MYSQL_READ_DEFAULT_GROUP,
|
||
MYSQL_SET_CHARSET_DIR, MYSQL_SET_CHARSET_NAME);
|
||
{$endif}
|
||
|
||
mysql_status = (MYSQL_STATUS_READY,
|
||
MYSQL_STATUS_GET_RESULT,
|
||
MYSQL_STATUS_USE_RESULT);
|
||
|
||
{$ifndef use_mysql_321}
|
||
(*
|
||
charset_info_st = Record
|
||
number : cardinal;
|
||
name : pchar;
|
||
ctype : pointer {uchar*};
|
||
to_lower : pointer {uchar*};
|
||
to_upper : pointer {uchar*};
|
||
sort_order : pointer {uchar*};
|
||
strxfrm_multiply : cardinal;
|
||
|
||
{ einige nicht n<>her definierte Felder }
|
||
a, strxfrm, strnncoll, strnxfrm, like_range : pointer;
|
||
mbmaxlen : cardinal;
|
||
ismbchar, ismbhead, mbcharlen : pointer;
|
||
end;
|
||
*)
|
||
{$endif}
|
||
|
||
st_mysql = Record
|
||
NET : TNET; { Communication parameters }
|
||
{$ifndef use_mysql_321}
|
||
connector_fd : gptr;
|
||
{$endif}
|
||
host,user,passwd,unix_socket,server_version,host_info,
|
||
info,db : pchar;
|
||
port,client_flag,server_capabilities : cardinal;
|
||
protocol_version : cardinal;
|
||
field_count : cardinal;
|
||
{$ifndef use_mysql_321}
|
||
server_status : cardinal;
|
||
{$endif}
|
||
thread_id : ptruint; { Id for connection in server }
|
||
affected_rows : my_ulonglong;
|
||
insert_id : my_ulonglong; { id if insert on table with NEXTNR }
|
||
extra_info : my_ulonglong; { Used by mysqlshow }
|
||
packet_length : sizeint;
|
||
status : mysql_status;
|
||
fields : PMYSQL_FIELD;
|
||
field_alloc : TMEM_ROOT;
|
||
free_me : my_bool; { If free in mysql_close }
|
||
reconnect : my_bool; { set to 1 if automatic reconnect }
|
||
options : st_mysql_options;
|
||
{$ifndef use_mysql_321}
|
||
scramble_buf : array[0..8] of char;
|
||
charset : pointer { struct charset_info_st};
|
||
server_language : cardinal;
|
||
{$endif}
|
||
end;
|
||
TMYSQL = st_mysql;
|
||
PMYSQL = ^TMYSQL;
|
||
|
||
|
||
st_mysql_res = record
|
||
row_count : my_ulonglong;
|
||
field_count, current_field : cardinal;
|
||
fields : PMYSQL_FIELD;
|
||
data : PMYSQL_DATA;
|
||
data_cursor : PMYSQL_ROWS;
|
||
field_alloc : TMEM_ROOT;
|
||
row : TMYSQL_ROW; { If unbuffered read }
|
||
current_row : TMYSQL_ROW; { buffer to current row }
|
||
lengths : psizeint; { column lengths of current row }
|
||
handle : PMYSQL; { for unbuffered reads }
|
||
eof : my_bool; { Used my mysql_fetch_row }
|
||
end;
|
||
TMYSQL_RES = st_mysql_res;
|
||
PMYSQL_RES = ^TMYSQL_RES;
|
||
|
||
|
||
{ Translated Macros }
|
||
|
||
Function mysql_num_rows (res : PMYSQL_RES) : my_ulonglong;
|
||
Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
|
||
Function mysql_eof(res : PMYSQL_RES) : my_bool;
|
||
Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
|
||
Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
|
||
Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
|
||
Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
|
||
Function mysql_affected_rows(mysql : PMYSQL): my_ulonglong;
|
||
Function mysql_insert_id(mysql : PMYSQL): my_ulonglong;
|
||
Function mysql_errno(mysql : PMYSQL) : Cardinal;
|
||
Function mysql_info(mysql : PMYSQL): Pchar;
|
||
Function mysql_reload(mysql : PMYSQL) : Longint;
|
||
Function mysql_thread_id(mysql : PMYSQL) : ptruint;
|
||
Function mysql_error(mysql : PMYSQL) : pchar;
|
||
|
||
{ Original functions }
|
||
|
||
function mysql_connect (mysql : PMYSQL; host,user,passwd: pchar) : PMYSQL;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_connect';
|
||
function mysql_real_connect (mysql : PMYSQL; const host,user,passwd : pchar;
|
||
port : cardinal;
|
||
unix_socket : pchar;
|
||
clientflag : cardinal) : PMYSQL;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib;
|
||
|
||
function mysql_close(sock : PMYSQL) : longint ;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_close';
|
||
function mysql_select_db(MYSQL : PMYSQL; db : Pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_select_db';
|
||
function mysql_query(mysql : PMYSQL; q : pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_query';
|
||
function mysql_real_query(mysql : PMYSQL; q : Pchar; length : longint) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_real_query';
|
||
function mysql_create_db(mysql : PMYSQL; db : pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_create_db';
|
||
Function mysql_drop_db(mysql : PMYSQL; DB : Pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_drop_db';
|
||
Function mysql_shutdown(mysql : PMYSQL) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_shutdown';
|
||
Function mysql_dump_debug_info(mysql : PMYSQL) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_dump_debug_info';
|
||
Function mysql_refresh(mysql : PMYSQL; refresh_options : cardinal) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_refresh';
|
||
Function mysql_kill(mysql : PMYSQL; pid : Cardinal) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_kill';
|
||
Function mysql_stat(mysql : PMYSQL) : Pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_stat';
|
||
Function mysql_get_server_info(mysql : PMYSQL) : pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_get_server_info';
|
||
Function mysql_get_client_info : pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib;
|
||
Function mysql_get_host_info(mysql : PMYSQL) : pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_get_host_info';
|
||
Function mysql_get_proto_info(mysql : PMYSQL) : Cardinal;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_get_proto_info';
|
||
Function mysql_list_dbs(mysql : PMYSQL;wild : Pchar) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_dbs';
|
||
Function mysql_list_tables(mysql : PMYSQL;Wild : Pchar) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_tables';
|
||
Function mysql_list_fields(mysql : PMYSQL; table,wild : pchar) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_fields';
|
||
Function mysql_list_processes(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_processes';
|
||
Function mysql_store_result(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_store_result';
|
||
Function mysql_use_result(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_use_result';
|
||
Procedure mysql_free_result(res : PMYSQL_RES);{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_free_result';
|
||
Procedure mysql_data_seek(mysql : PMYSQL_RES; offs : cardinal);{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_data_seek';
|
||
Function mysql_row_seek(mysql : PMYSQL_RES; Offs: TMYSQL_ROW_OFFSET): TMYSQL_ROW_OFFSET;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_row_seek';
|
||
Function mysql_field_seek(musql : PMYSQL_RES;offs : TMYSQL_FIELD_OFFSET): TMYSQL_FIELD_OFFSET;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_field_seek';
|
||
function mysql_fetch_row(mysql : PMYSQL_RES) : TMYSQL_ROW;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_fetch_row';
|
||
function mysql_fetch_lengths(mysql : PMYSQL_RES) : PCardinal;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_fetch_lengths';
|
||
function mysql_fetch_field(handle : PMYSQL_RES) : PMYSQL_FIELD;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_fetch_field';
|
||
Function mysql_escape_string(escto,escfrom : pchar; length : Cardinal) : cardinal;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_escape_string';
|
||
Procedure mysql_debug(debug : pchar);{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_debug';
|
||
|
||
implementation
|
||
|
||
|
||
|
||
Function mysql_error(mysql : PMYSQL) : pchar;
|
||
|
||
begin
|
||
mysql_error:=mysql^.net.last_error
|
||
end;
|
||
|
||
Function mysql_num_rows (res : PMYSQL_RES) : my_ulonglong;
|
||
|
||
begin
|
||
mysql_num_rows:=res^.row_count
|
||
end;
|
||
|
||
Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
|
||
|
||
begin
|
||
mysql_num_fields:=res^.field_count
|
||
end;
|
||
|
||
Function mysql_eof(res : PMYSQL_RES) : my_bool;
|
||
|
||
begin
|
||
mysql_eof:=res^.eof
|
||
end;
|
||
|
||
Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
|
||
|
||
begin
|
||
mysql_fetch_field_direct:=res^.fields[fieldnr];
|
||
end;
|
||
|
||
Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
|
||
|
||
begin
|
||
mysql_fetch_fields:=res^.fields
|
||
end;
|
||
|
||
Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
|
||
|
||
begin
|
||
mysql_row_tell:=res^.data_cursor
|
||
end;
|
||
|
||
Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
|
||
|
||
begin
|
||
mysql_field_tell:=res^.current_field
|
||
end;
|
||
|
||
Function mysql_affected_rows(mysql : PMYSQL): my_ulonglong;
|
||
|
||
begin
|
||
mysql_affected_rows:=mysql^.affected_rows
|
||
end;
|
||
|
||
Function mysql_insert_id(mysql : PMYSQL): my_ulonglong;
|
||
|
||
begin
|
||
mysql_insert_id:=mysql^.insert_id
|
||
end;
|
||
|
||
Function mysql_errno(mysql : PMYSQL) : Cardinal;
|
||
|
||
begin
|
||
mysql_errno:=mysql^.net.last_errno
|
||
end;
|
||
|
||
Function mysql_info(mysql : PMYSQL): Pchar;
|
||
|
||
begin
|
||
mysql_info:=mysql^.info
|
||
end;
|
||
|
||
Function mysql_reload(mysql : PMYSQL) : Longint;
|
||
|
||
begin
|
||
mysql_reload:=mysql_refresh(mysql,REFRESH_GRANT)
|
||
end;
|
||
|
||
Function mysql_thread_id(mysql : PMysql) : ptruint;
|
||
|
||
begin
|
||
mysql_thread_id:=mysql^.thread_id
|
||
end;
|
||
|
||
end.
|
||
|
||
{
|
||
$Log$
|
||
Revision 1.3 2004-11-21 16:33:55 peter
|
||
* external fixes
|
||
|
||
Revision 1.2 2004/11/02 23:33:32 florian
|
||
* 64 bit fixes
|
||
|
||
Revision 1.1 2004/09/30 19:34:47 michael
|
||
+ Split everything in version 3 and version 4
|
||
|
||
Revision 1.1 2004/09/28 18:38:23 michael
|
||
+ Moved to subdir, switching to version 4.0
|
||
|
||
Revision 1.6 2004/08/05 10:36:26 olle
|
||
+ added, on unixes, $linklib mysqlclient
|
||
|
||
Revision 1.5 2004/03/29 18:16:02 florian
|
||
+ darwin support
|
||
|
||
Revision 1.4 2002/09/10 19:44:28 michael
|
||
+ Changed stdcall to appropriate OS calling declaration
|
||
|
||
Revision 1.3 2002/09/07 15:42:52 peter
|
||
* old logs removed and tabs fixed
|
||
|
||
Revision 1.2 2002/08/26 17:52:31 michael
|
||
+ Upgraded to 3.23
|
||
|
||
}
|