mysql.pp 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340
  1. { $Id$ }
  2. unit mysql;
  3. {
  4. Import unit for the mysql header files.
  5. Translated form the original mysql.h by Michael Van Canneyt
  6. ([email protected])
  7. }
  8. interface
  9. uses mysql_com;
  10. {$ifdef win32}
  11. Const mysqllib = 'libmysql';
  12. {$else}
  13. Const mysqllib = 'mysqlclient';
  14. {$endif}
  15. {$ifndef win32}
  16. {$linklib c}
  17. {$linklib m}
  18. {$endif}
  19. { All is 4-byte aligned on my machine. }
  20. {$packrecords 4}
  21. type
  22. my_bool = byte;
  23. gptr = pchar;
  24. Socket = Longint;
  25. PCardinal = ^Cardinal;
  26. {$ifdef Unix}
  27. Var
  28. mysql_port : cardinal; external name 'mysql_port';
  29. mysql_unix_port : pchar; external name 'mysql_unix_port';
  30. {$endif}
  31. {
  32. #define IS_PRI_KEY(n) ((n) & PRI_KEY_FLAG)
  33. #define IS_NOT_NULL(n) ((n) & NOT_NULL_FLAG)
  34. #define IS_BLOB(n) ((n) & BLOB_FLAG)
  35. #define IS_NUM(t) ((t) <= FIELD_TYPE_INT24)
  36. }
  37. Type
  38. st_mysql_field = record
  39. name : Pchar; { Name of column }
  40. table : pchar; { Table of column if column was a field }
  41. def: pchar; { Default value (set by mysql_list_fields) }
  42. ftype : enum_field_types; { Type of field. See mysql_com.h for types }
  43. length : cardinal; { Width of column }
  44. max_length : cardinal; { Max width of selected set }
  45. flags : cardinal; { Div flags }
  46. decimals : cardinal; { Number of decimals in field }
  47. end;
  48. TMYSQL_FIELD = st_mysql_field;
  49. PMYSQL_FIELD = ^TMYSQL_FIELD;
  50. TMYSQL_ROW = PPchar; { return data as array of strings }
  51. TMYSQL_FIELD_OFFSET = cardinal; { offset to current field }
  52. {$ifndef oldmysql}
  53. my_ulonglong=qword;
  54. {$else}
  55. my_longlong=cardinal;
  56. {$endif}
  57. PST_MYSQL_Rows = ^st_mysql_rows;
  58. st_mysql_rows = Record
  59. next : pst_mysql_rows; { list of rows }
  60. Data : TMYSQL_ROW;
  61. end;
  62. TMYSQL_ROWS = st_mysql_rows;
  63. PMYSQL_ROWS = ^TMYSQL_ROWS;
  64. TMYSQL_ROW_OFFSET = PMYSQL_ROWS; { offset to current row }
  65. st_mysql_data = record
  66. rows : my_ulonglong;
  67. fields : cardinal;
  68. data : PMYSQL_ROWS;
  69. alloc : TMEM_ROOT;
  70. end;
  71. TMYSQL_DATA = st_mysql_data;
  72. PMYSQL_DATA = ^TMYSQL_DATA;
  73. st_mysql_options = record
  74. connect_timeout,client_flag : cardinal;
  75. compress,named_pipe : my_bool;
  76. port : cardinal;
  77. host,init_command,user,password,unix_socket,db : pchar;
  78. my_cnf_file,my_cnf_group : pchar;
  79. end;
  80. mysql_status = (MYSQL_STATUS_READY,
  81. MYSQL_STATUS_GET_RESULT,
  82. MYSQL_STATUS_USE_RESULT);
  83. st_mysql = Record
  84. NET : TNET; { Communication parameters }
  85. host,user,passwd,unix_socket,server_version,host_info,
  86. info,db : pchar;
  87. port,client_flag,server_capabilities : cardinal;
  88. protocol_version : cardinal;
  89. field_count : cardinal;
  90. thread_id : cardinal; { Id for connection in server }
  91. affected_rows : my_ulonglong;
  92. insert_id : my_ulonglong; { id if insert on table with NEXTNR }
  93. extra_info : my_ulonglong; { Used by mysqlshow }
  94. packet_length : cardinal;
  95. status : mysql_status;
  96. fields : PMYSQL_FIELD;
  97. field_alloc : TMEM_ROOT;
  98. free_me : my_bool; { If free in mysql_close }
  99. reconnect : my_bool; { set to 1 if automatic reconnect }
  100. options : st_mysql_options;
  101. end;
  102. TMYSQL = st_mysql;
  103. PMYSQL = ^TMYSQL;
  104. st_mysql_res = record
  105. row_count : my_ulonglong;
  106. field_count, current_field : cardinal;
  107. fields : PMYSQL_FIELD;
  108. data : PMYSQL_DATA;
  109. data_cursor : PMYSQL_ROWS;
  110. field_alloc : TMEM_ROOT;
  111. row : TMYSQL_ROW; { If unbuffered read }
  112. current_row : TMYSQL_ROW; { buffer to current row }
  113. lengths : pcardinal; { column lengths of current row }
  114. handle : PMYSQL; { for unbuffered reads }
  115. eof : my_bool; { Used my mysql_fetch_row }
  116. end;
  117. TMYSQL_RES = st_mysql_res;
  118. PMYSQL_RES = ^TMYSQL_RES;
  119. { Translated Macros }
  120. Function mysql_num_rows (res : PMYSQL_RES) : my_ulonglong;
  121. Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
  122. Function mysql_eof(res : PMYSQL_RES) : my_bool;
  123. Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
  124. Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
  125. Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
  126. Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
  127. Function mysql_affected_rows(mysql : PMYSQL): my_ulonglong;
  128. Function mysql_insert_id(mysql : PMYSQL): my_ulonglong;
  129. Function mysql_errno(mysql : PMYSQL) : Cardinal;
  130. Function mysql_info(mysql : PMYSQL): Pchar;
  131. Function mysql_reload(mysql : PMYSQL) : Longint;
  132. Function mysql_thread_id(mysql : PMYSQL) : Cardinal;
  133. Function mysql_error(mysql : PMYSQL) : pchar;
  134. { Original functions }
  135. Function mysql_connect (mysql : PMYSQL; host,user,passwd: pchar) : PMYSQL; {$ifdef win32} stdcall {$else} cdecl {$endif};
  136. Function mysql_real_connect (mysql : PMYSQL; const host,user,passwd : pchar;
  137. port : cardinal;
  138. unix_socket : pchar;
  139. clientflag : cardinal) : PMYSQL;{$ifdef win32} stdcall {$else} cdecl {$endif};
  140. Function mysql_close(sock : PMYSQL) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  141. Function mysql_select_db(MYSQL : PMYSQL; db : Pchar) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  142. Function mysql_query(mysql : PMYSQL; q : pchar) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  143. Function mysql_real_query(mysql : PMYSQL; q : Pchar; length : longint) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  144. Function mysql_create_db(mysql : PMYSQL; db : pchar) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  145. Function mysql_drop_db(mysql : PMYSQL; DB : Pchar) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  146. Function mysql_shutdown(mysql : PMYSQL) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  147. Function mysql_dump_debug_info(mysql : PMYSQL) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  148. Function mysql_refresh(mysql : PMYSQL; refresh_options : cardinal) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  149. Function mysql_kill(mysql : PMYSQL; pid : Cardinal) : longint; {$ifdef win32} stdcall {$else} cdecl {$endif};
  150. Function mysql_stat(mysql : PMYSQL) : Pchar; {$ifdef win32} stdcall {$else} cdecl {$endif};
  151. Function mysql_get_server_info(mysql : PMYSQL) : pchar; {$ifdef win32} stdcall {$else} cdecl {$endif};
  152. Function mysql_get_client_info : pchar; {$ifdef win32} stdcall {$else} cdecl {$endif};
  153. Function mysql_get_host_info(mysql : PMYSQL) : pchar; {$ifdef win32} stdcall {$else} cdecl {$endif};
  154. Function mysql_get_proto_info(mysql : PMYSQL) : Cardinal; {$ifdef win32} stdcall {$else} cdecl {$endif};
  155. Function mysql_list_dbs(mysql : PMYSQL;wild : Pchar) : PMYSQL_RES; {$ifdef win32} stdcall {$else} cdecl {$endif};
  156. Function mysql_list_tables(mysql : PMYSQL;Wild : Pchar) : PMYSQL_RES; {$ifdef win32} stdcall {$else} cdecl {$endif};
  157. Function mysql_list_fields(mysql : PMYSQL; table,wild : pchar) : PMYSQL_RES; {$ifdef win32} stdcall {$else} cdecl {$endif};
  158. Function mysql_list_processes(mysql : PMYSQL) : PMYSQL_RES; {$ifdef win32} stdcall {$else} cdecl {$endif};
  159. Function mysql_store_result(mysql : PMYSQL) : PMYSQL_RES; {$ifdef win32} stdcall {$else} cdecl {$endif};
  160. Function mysql_use_result(mysql : PMYSQL) : PMYSQL_RES; {$ifdef win32} stdcall {$else} cdecl {$endif};
  161. Procedure mysql_free_result(res : PMYSQL_RES);{$ifdef win32} stdcall {$else} cdecl {$endif};
  162. Procedure mysql_data_seek(mysql : PMYSQL_RES; offs : cardinal);{$ifdef win32} stdcall {$else} cdecl {$endif};
  163. Function mysql_row_seek(mysql : PMYSQL_RES; Offs: TMYSQL_ROW_OFFSET): TMYSQL_ROW_OFFSET; {$ifdef win32} stdcall {$else} cdecl {$endif};
  164. Function mysql_field_seek(musql : PMYSQL_RES;offs : TMYSQL_FIELD_OFFSET): TMYSQL_FIELD_OFFSET; {$ifdef win32} stdcall {$else} cdecl {$endif};
  165. Function mysql_fetch_row(mysql : PMYSQL_RES) : TMYSQL_ROW; {$ifdef win32} stdcall {$else} cdecl {$endif};
  166. Function mysql_fetch_lengths(mysql : PMYSQL_RES) : PCardinal; {$ifdef win32} stdcall {$else} cdecl {$endif};
  167. Function mysql_fetch_field(handle : PMYSQL_RES) : PMYSQL_FIELD; {$ifdef win32} stdcall {$else} cdecl {$endif};
  168. Function mysql_escape_string(escto,escfrom : pchar; length : Cardinal) : cardinal; {$ifdef win32} stdcall {$else} cdecl {$endif};
  169. Procedure mysql_debug(debug : pchar);{$ifdef win32} stdcall {$else} cdecl {$endif};
  170. implementation
  171. function mysql_connect (mysql : PMYSQL; host,user,passwd: pchar) : PMYSQL;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_connect';
  172. function mysql_real_connect (mysql : PMYSQL; const host,user,passwd : pchar;
  173. port : cardinal;
  174. unix_socket : pchar;
  175. clientflag : cardinal) : PMYSQL;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib;
  176. function mysql_close(sock : PMYSQL) : longint ;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_close';
  177. function mysql_select_db(MYSQL : PMYSQL; db : Pchar) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_select_db';
  178. function mysql_query(mysql : PMYSQL; q : pchar) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_query';
  179. function mysql_real_query(mysql : PMYSQL; q : Pchar; length : longint) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_real_query';
  180. function mysql_create_db(mysql : PMYSQL; db : pchar) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_create_db';
  181. Function mysql_drop_db(mysql : PMYSQL; DB : Pchar) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_drop_db';
  182. Function mysql_shutdown(mysql : PMYSQL) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_shutdown';
  183. Function mysql_dump_debug_info(mysql : PMYSQL) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_dump_debug_info';
  184. Function mysql_refresh(mysql : PMYSQL; refresh_options : cardinal) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_refresh';
  185. Function mysql_kill(mysql : PMYSQL; pid : Cardinal) : longint;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_kill';
  186. Function mysql_stat(mysql : PMYSQL) : Pchar;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_stat';
  187. Function mysql_get_server_info(mysql : PMYSQL) : pchar;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_get_server_info';
  188. Function mysql_get_client_info : pchar;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib;
  189. Function mysql_get_host_info(mysql : PMYSQL) : pchar;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_get_host_info';
  190. Function mysql_get_proto_info(mysql : PMYSQL) : Cardinal;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_get_proto_info';
  191. Function mysql_list_dbs(mysql : PMYSQL;wild : Pchar) : PMYSQL_RES;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_list_dbs';
  192. Function mysql_list_tables(mysql : PMYSQL;Wild : Pchar) : PMYSQL_RES;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_list_tables';
  193. Function mysql_list_fields(mysql : PMYSQL; table,wild : pchar) : PMYSQL_RES;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_list_fields';
  194. Function mysql_list_processes(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_list_processes';
  195. Function mysql_store_result(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_store_result';
  196. Function mysql_use_result(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_use_result';
  197. Procedure mysql_free_result(res : PMYSQL_RES);{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_free_result';
  198. Procedure mysql_data_seek(mysql : PMYSQL_RES; offs : cardinal);{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_data_seek';
  199. 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';
  200. 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';
  201. function mysql_fetch_row(mysql : PMYSQL_RES) : TMYSQL_ROW;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_fetch_row';
  202. function mysql_fetch_lengths(mysql : PMYSQL_RES) : PCardinal;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_fetch_lengths';
  203. function mysql_fetch_field(handle : PMYSQL_RES) : PMYSQL_FIELD;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_fetch_field';
  204. Function mysql_escape_string(escto,escfrom : pchar; length : Cardinal) : cardinal;{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_escape_string';
  205. Procedure mysql_debug(debug : pchar);{$ifdef win32} stdcall {$else} cdecl {$endif}; external mysqllib name 'mysql_debug';
  206. Function mysql_error(mysql : PMYSQL) : pchar;
  207. begin
  208. mysql_error:=mysql^.net.last_error
  209. end;
  210. Function mysql_num_rows (res : PMYSQL_RES) : my_ulonglong;
  211. begin
  212. mysql_num_rows:=res^.row_count
  213. end;
  214. Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
  215. begin
  216. mysql_num_fields:=res^.field_count
  217. end;
  218. Function mysql_eof(res : PMYSQL_RES) : my_bool;
  219. begin
  220. mysql_eof:=res^.eof
  221. end;
  222. Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
  223. begin
  224. mysql_fetch_field_direct:=res^.fields[fieldnr];
  225. end;
  226. Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
  227. begin
  228. mysql_fetch_fields:=res^.fields
  229. end;
  230. Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
  231. begin
  232. mysql_row_tell:=res^.data_cursor
  233. end;
  234. Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
  235. begin
  236. mysql_field_tell:=res^.current_field
  237. end;
  238. Function mysql_affected_rows(mysql : PMYSQL): my_ulonglong;
  239. begin
  240. mysql_affected_rows:=mysql^.affected_rows
  241. end;
  242. Function mysql_insert_id(mysql : PMYSQL): my_ulonglong;
  243. begin
  244. mysql_insert_id:=mysql^.insert_id
  245. end;
  246. Function mysql_errno(mysql : PMYSQL) : Cardinal;
  247. begin
  248. mysql_errno:=mysql^.net.last_errno
  249. end;
  250. Function mysql_info(mysql : PMYSQL): Pchar;
  251. begin
  252. mysql_info:=mysql^.info
  253. end;
  254. Function mysql_reload(mysql : PMYSQL) : Longint;
  255. begin
  256. mysql_reload:=mysql_refresh(mysql,REFRESH_GRANT)
  257. end;
  258. Function mysql_thread_id(mysql : PMysql) : Cardinal;
  259. begin
  260. mysql_thread_id:=mysql^.thread_id
  261. end;
  262. end.
  263. {
  264. $Log$
  265. Revision 1.1 2002-01-29 17:54:53 peter
  266. * splitted to base and extra
  267. Revision 1.5 2001/03/13 08:50:38 michael
  268. + merged Fixed calling convention for win32
  269. Revision 1.4 2000/12/03 13:41:39 sg
  270. * Fixed small merging bug by Michael
  271. Revision 1.3 2000/12/02 15:24:37 michael
  272. + Merged changes from fixbranch
  273. }