mysql3.pp 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. { $Id$ }
  2. unit mysql3;
  3. {$undef use_mysql_321} { if undefined, use mysql 3.23 interface }
  4. {
  5. Import unit for the mysql header files.
  6. Translated form the original mysql.h by Michael Van Canneyt
  7. ([email protected])
  8. updated to mysql version 3.23 header files by Bernhard Steffen
  9. ([email protected])
  10. }
  11. {$r+,i+,o+}
  12. interface
  13. uses mysql3_com, mysql3_version;
  14. {$ifdef win32}
  15. Const mysqllib = 'libmysql';
  16. {$else}
  17. Const mysqllib = 'mysqlclient';
  18. {$endif}
  19. {$ifndef win32}
  20. {$linklib c}
  21. {$linklib m}
  22. {$linklib mysqlclient}
  23. {$endif}
  24. {$packrecords C}
  25. type
  26. my_bool = byte;
  27. gptr = pchar;
  28. Socket = Longint;
  29. PCardinal = ^Cardinal;
  30. {$ifdef linux}
  31. Var
  32. mysql_port : cardinal; external name 'mysql_port';
  33. mysql_unix_port : pchar; external name 'mysql_unix_port';
  34. {$endif}
  35. {$ifdef darwin}
  36. Var
  37. mysql_port : cardinal; external mysqllib name 'mysql_port';
  38. mysql_unix_port : pchar; external mysqllib name 'mysql_unix_port';
  39. {$endif}
  40. {
  41. #define IS_PRI_KEY(n) ((n) & PRI_KEY_FLAG)
  42. #define IS_NOT_NULL(n) ((n) & NOT_NULL_FLAG)
  43. #define IS_BLOB(n) ((n) & BLOB_FLAG)
  44. #define IS_NUM(t) ((t) <= FIELD_TYPE_INT24)
  45. }
  46. Type
  47. st_mysql_field = record
  48. name : Pchar; { Name of column }
  49. table : pchar; { Table of column if column was a field }
  50. def: pchar; { Default value (set by mysql_list_fields) }
  51. ftype : enum_field_types; { Type of field. See mysql_com.h for types }
  52. length : cardinal; { Width of column }
  53. max_length : cardinal; { Max width of selected set }
  54. flags : cardinal; { Div flags }
  55. decimals : cardinal; { Number of decimals in field }
  56. end;
  57. TMYSQL_FIELD = st_mysql_field;
  58. PMYSQL_FIELD = ^TMYSQL_FIELD;
  59. TMYSQL_ROW = PPchar; { return data as array of strings }
  60. TMYSQL_FIELD_OFFSET = cardinal; { offset to current field }
  61. {$ifndef oldmysql}
  62. my_ulonglong=qword;
  63. {$else}
  64. my_longlong=cardinal;
  65. {$endif}
  66. PST_MYSQL_Rows = ^st_mysql_rows;
  67. st_mysql_rows = Record
  68. next : pst_mysql_rows; { list of rows }
  69. Data : TMYSQL_ROW;
  70. end;
  71. TMYSQL_ROWS = st_mysql_rows;
  72. PMYSQL_ROWS = ^TMYSQL_ROWS;
  73. TMYSQL_ROW_OFFSET = PMYSQL_ROWS; { offset to current row }
  74. st_mysql_data = record
  75. rows : my_ulonglong;
  76. fields : cardinal;
  77. data : PMYSQL_ROWS;
  78. alloc : TMEM_ROOT;
  79. end;
  80. TMYSQL_DATA = st_mysql_data;
  81. PMYSQL_DATA = ^TMYSQL_DATA;
  82. st_mysql_options = record
  83. connect_timeout,client_flag : cardinal;
  84. compress,named_pipe : my_bool;
  85. port : cardinal;
  86. host,init_command,user,password,unix_socket,db : pchar;
  87. my_cnf_file,my_cnf_group : pchar;
  88. {$ifndef use_mysql_321}
  89. charset_dir, charset_name : pchar;
  90. use_ssl : my_bool;
  91. ssl_key, ssl_cert, ssl_ca, ssl_capath : pchar;
  92. {$endif}
  93. end;
  94. {$ifndef use_mysql_321}
  95. mysql_option = (MYSQL_OPT_CONNECT_TIMEOUT, MYSQL_OPT_COMPRESS,
  96. MYSQL_OPT_NAMED_PIPE, MYSQL_INIT_COMMAND,
  97. MYSQL_READ_DEFAULT_FILE, MYSQL_READ_DEFAULT_GROUP,
  98. MYSQL_SET_CHARSET_DIR, MYSQL_SET_CHARSET_NAME);
  99. {$endif}
  100. mysql_status = (MYSQL_STATUS_READY,
  101. MYSQL_STATUS_GET_RESULT,
  102. MYSQL_STATUS_USE_RESULT);
  103. {$ifndef use_mysql_321}
  104. (*
  105. charset_info_st = Record
  106. number : cardinal;
  107. name : pchar;
  108. ctype : pointer {uchar*};
  109. to_lower : pointer {uchar*};
  110. to_upper : pointer {uchar*};
  111. sort_order : pointer {uchar*};
  112. strxfrm_multiply : cardinal;
  113. { einige nicht näher definierte Felder }
  114. a, strxfrm, strnncoll, strnxfrm, like_range : pointer;
  115. mbmaxlen : cardinal;
  116. ismbchar, ismbhead, mbcharlen : pointer;
  117. end;
  118. *)
  119. {$endif}
  120. st_mysql = Record
  121. NET : TNET; { Communication parameters }
  122. {$ifndef use_mysql_321}
  123. connector_fd : gptr;
  124. {$endif}
  125. host,user,passwd,unix_socket,server_version,host_info,
  126. info,db : pchar;
  127. port,client_flag,server_capabilities : cardinal;
  128. protocol_version : cardinal;
  129. field_count : cardinal;
  130. {$ifndef use_mysql_321}
  131. server_status : cardinal;
  132. {$endif}
  133. thread_id : cardinal; { Id for connection in server }
  134. affected_rows : my_ulonglong;
  135. insert_id : my_ulonglong; { id if insert on table with NEXTNR }
  136. extra_info : my_ulonglong; { Used by mysqlshow }
  137. packet_length : cardinal;
  138. status : mysql_status;
  139. fields : PMYSQL_FIELD;
  140. field_alloc : TMEM_ROOT;
  141. free_me : my_bool; { If free in mysql_close }
  142. reconnect : my_bool; { set to 1 if automatic reconnect }
  143. options : st_mysql_options;
  144. {$ifndef use_mysql_321}
  145. scramble_buf : array[0..8] of char;
  146. charset : pointer { struct charset_info_st};
  147. server_language : cardinal;
  148. {$endif}
  149. end;
  150. TMYSQL = st_mysql;
  151. PMYSQL = ^TMYSQL;
  152. st_mysql_res = record
  153. row_count : my_ulonglong;
  154. field_count, current_field : cardinal;
  155. fields : PMYSQL_FIELD;
  156. data : PMYSQL_DATA;
  157. data_cursor : PMYSQL_ROWS;
  158. field_alloc : TMEM_ROOT;
  159. row : TMYSQL_ROW; { If unbuffered read }
  160. current_row : TMYSQL_ROW; { buffer to current row }
  161. lengths : pcardinal; { column lengths of current row }
  162. handle : PMYSQL; { for unbuffered reads }
  163. eof : my_bool; { Used my mysql_fetch_row }
  164. end;
  165. TMYSQL_RES = st_mysql_res;
  166. PMYSQL_RES = ^TMYSQL_RES;
  167. { Translated Macros }
  168. Function mysql_num_rows (res : PMYSQL_RES) : my_ulonglong;
  169. Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
  170. Function mysql_eof(res : PMYSQL_RES) : my_bool;
  171. Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
  172. Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
  173. Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
  174. Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
  175. Function mysql_affected_rows(mysql : PMYSQL): my_ulonglong;
  176. Function mysql_insert_id(mysql : PMYSQL): my_ulonglong;
  177. Function mysql_errno(mysql : PMYSQL) : Cardinal;
  178. Function mysql_info(mysql : PMYSQL): Pchar;
  179. Function mysql_reload(mysql : PMYSQL) : Longint;
  180. Function mysql_thread_id(mysql : PMYSQL) : Cardinal;
  181. Function mysql_error(mysql : PMYSQL) : pchar;
  182. { Original functions }
  183. Function mysql_connect (mysql : PMYSQL; host,user,passwd: pchar) : PMYSQL; {$ifdef win32}stdcall{$else}cdecl{$endif};
  184. Function mysql_real_connect (mysql : PMYSQL; const host,user,passwd : pchar;
  185. port : cardinal;
  186. unix_socket : pchar;
  187. clientflag : cardinal) : PMYSQL;{$ifdef win32}stdcall{$else}cdecl{$endif};
  188. Function mysql_close(sock : PMYSQL) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  189. Function mysql_select_db(MYSQL : PMYSQL; db : Pchar) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  190. Function mysql_query(mysql : PMYSQL; q : pchar) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  191. Function mysql_real_query(mysql : PMYSQL; q : Pchar; length : longint) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  192. Function mysql_create_db(mysql : PMYSQL; db : pchar) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  193. Function mysql_drop_db(mysql : PMYSQL; DB : Pchar) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  194. Function mysql_shutdown(mysql : PMYSQL) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  195. Function mysql_dump_debug_info(mysql : PMYSQL) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  196. Function mysql_refresh(mysql : PMYSQL; refresh_options : cardinal) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  197. Function mysql_kill(mysql : PMYSQL; pid : Cardinal) : longint; {$ifdef win32}stdcall{$else}cdecl{$endif};
  198. Function mysql_stat(mysql : PMYSQL) : Pchar; {$ifdef win32}stdcall{$else}cdecl{$endif};
  199. Function mysql_get_server_info(mysql : PMYSQL) : pchar; {$ifdef win32}stdcall{$else}cdecl{$endif};
  200. Function mysql_get_client_info : pchar; {$ifdef win32}stdcall{$else}cdecl{$endif};
  201. Function mysql_get_host_info(mysql : PMYSQL) : pchar; {$ifdef win32}stdcall{$else}cdecl{$endif};
  202. Function mysql_get_proto_info(mysql : PMYSQL) : Cardinal; {$ifdef win32}stdcall{$else}cdecl{$endif};
  203. Function mysql_list_dbs(mysql : PMYSQL;wild : Pchar) : PMYSQL_RES; {$ifdef win32}stdcall{$else}cdecl{$endif};
  204. Function mysql_list_tables(mysql : PMYSQL;Wild : Pchar) : PMYSQL_RES; {$ifdef win32}stdcall{$else}cdecl{$endif};
  205. Function mysql_list_fields(mysql : PMYSQL; table,wild : pchar) : PMYSQL_RES; {$ifdef win32}stdcall{$else}cdecl{$endif};
  206. Function mysql_list_processes(mysql : PMYSQL) : PMYSQL_RES; {$ifdef win32}stdcall{$else}cdecl{$endif};
  207. Function mysql_store_result(mysql : PMYSQL) : PMYSQL_RES; {$ifdef win32}stdcall{$else}cdecl{$endif};
  208. Function mysql_use_result(mysql : PMYSQL) : PMYSQL_RES; {$ifdef win32}stdcall{$else}cdecl{$endif};
  209. Procedure mysql_free_result(res : PMYSQL_RES);{$ifdef win32}stdcall{$else}cdecl{$endif};
  210. Procedure mysql_data_seek(mysql : PMYSQL_RES; offs : cardinal);{$ifdef win32}stdcall{$else}cdecl{$endif};
  211. Function mysql_row_seek(mysql : PMYSQL_RES; Offs: TMYSQL_ROW_OFFSET): TMYSQL_ROW_OFFSET; {$ifdef win32}stdcall{$else}cdecl{$endif};
  212. Function mysql_field_seek(musql : PMYSQL_RES;offs : TMYSQL_FIELD_OFFSET): TMYSQL_FIELD_OFFSET; {$ifdef win32}stdcall{$else}cdecl{$endif};
  213. Function mysql_fetch_row(mysql : PMYSQL_RES) : TMYSQL_ROW; {$ifdef win32}stdcall{$else}cdecl{$endif};
  214. Function mysql_fetch_lengths(mysql : PMYSQL_RES) : PCardinal; {$ifdef win32}stdcall{$else}cdecl{$endif};
  215. Function mysql_fetch_field(handle : PMYSQL_RES) : PMYSQL_FIELD; {$ifdef win32}stdcall{$else}cdecl{$endif};
  216. Function mysql_escape_string(escto,escfrom : pchar; length : Cardinal) : cardinal; {$ifdef win32}stdcall{$else}cdecl{$endif};
  217. Procedure mysql_debug(debug : pchar);{$ifdef win32}stdcall{$else}cdecl{$endif};
  218. implementation
  219. function mysql_connect (mysql : PMYSQL; host,user,passwd: pchar) : PMYSQL;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_connect';
  220. function mysql_real_connect (mysql : PMYSQL; const host,user,passwd : pchar;
  221. port : cardinal;
  222. unix_socket : pchar;
  223. clientflag : cardinal) : PMYSQL;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib;
  224. function mysql_close(sock : PMYSQL) : longint ;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_close';
  225. function mysql_select_db(MYSQL : PMYSQL; db : Pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_select_db';
  226. function mysql_query(mysql : PMYSQL; q : pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_query';
  227. function mysql_real_query(mysql : PMYSQL; q : Pchar; length : longint) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_real_query';
  228. function mysql_create_db(mysql : PMYSQL; db : pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_create_db';
  229. Function mysql_drop_db(mysql : PMYSQL; DB : Pchar) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_drop_db';
  230. Function mysql_shutdown(mysql : PMYSQL) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_shutdown';
  231. Function mysql_dump_debug_info(mysql : PMYSQL) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_dump_debug_info';
  232. Function mysql_refresh(mysql : PMYSQL; refresh_options : cardinal) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_refresh';
  233. Function mysql_kill(mysql : PMYSQL; pid : Cardinal) : longint;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_kill';
  234. Function mysql_stat(mysql : PMYSQL) : Pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_stat';
  235. Function mysql_get_server_info(mysql : PMYSQL) : pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_get_server_info';
  236. Function mysql_get_client_info : pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib;
  237. Function mysql_get_host_info(mysql : PMYSQL) : pchar;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_get_host_info';
  238. Function mysql_get_proto_info(mysql : PMYSQL) : Cardinal;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_get_proto_info';
  239. Function mysql_list_dbs(mysql : PMYSQL;wild : Pchar) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_dbs';
  240. Function mysql_list_tables(mysql : PMYSQL;Wild : Pchar) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_tables';
  241. Function mysql_list_fields(mysql : PMYSQL; table,wild : pchar) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_fields';
  242. Function mysql_list_processes(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_list_processes';
  243. Function mysql_store_result(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_store_result';
  244. Function mysql_use_result(mysql : PMYSQL) : PMYSQL_RES;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_use_result';
  245. Procedure mysql_free_result(res : PMYSQL_RES);{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_free_result';
  246. Procedure mysql_data_seek(mysql : PMYSQL_RES; offs : cardinal);{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_data_seek';
  247. 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';
  248. 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';
  249. function mysql_fetch_row(mysql : PMYSQL_RES) : TMYSQL_ROW;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_fetch_row';
  250. function mysql_fetch_lengths(mysql : PMYSQL_RES) : PCardinal;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_fetch_lengths';
  251. function mysql_fetch_field(handle : PMYSQL_RES) : PMYSQL_FIELD;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_fetch_field';
  252. Function mysql_escape_string(escto,escfrom : pchar; length : Cardinal) : cardinal;{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_escape_string';
  253. Procedure mysql_debug(debug : pchar);{$ifdef win32}stdcall{$else}cdecl{$endif}; external mysqllib name 'mysql_debug';
  254. Function mysql_error(mysql : PMYSQL) : pchar;
  255. begin
  256. mysql_error:=mysql^.net.last_error
  257. end;
  258. Function mysql_num_rows (res : PMYSQL_RES) : my_ulonglong;
  259. begin
  260. mysql_num_rows:=res^.row_count
  261. end;
  262. Function mysql_num_fields(res : PMYSQL_RES) : Cardinal;
  263. begin
  264. mysql_num_fields:=res^.field_count
  265. end;
  266. Function mysql_eof(res : PMYSQL_RES) : my_bool;
  267. begin
  268. mysql_eof:=res^.eof
  269. end;
  270. Function mysql_fetch_field_direct(res : PMYSQL_RES; fieldnr : Cardinal) : TMYSQL_FIELD;
  271. begin
  272. mysql_fetch_field_direct:=res^.fields[fieldnr];
  273. end;
  274. Function mysql_fetch_fields(res : PMYSQL_RES) : PMYSQL_FIELD;
  275. begin
  276. mysql_fetch_fields:=res^.fields
  277. end;
  278. Function mysql_row_tell(res : PMYSQL_RES) : PMYSQL_ROWS;
  279. begin
  280. mysql_row_tell:=res^.data_cursor
  281. end;
  282. Function mysql_field_tell(res : PMYSQL_RES) : Cardinal;
  283. begin
  284. mysql_field_tell:=res^.current_field
  285. end;
  286. Function mysql_affected_rows(mysql : PMYSQL): my_ulonglong;
  287. begin
  288. mysql_affected_rows:=mysql^.affected_rows
  289. end;
  290. Function mysql_insert_id(mysql : PMYSQL): my_ulonglong;
  291. begin
  292. mysql_insert_id:=mysql^.insert_id
  293. end;
  294. Function mysql_errno(mysql : PMYSQL) : Cardinal;
  295. begin
  296. mysql_errno:=mysql^.net.last_errno
  297. end;
  298. Function mysql_info(mysql : PMYSQL): Pchar;
  299. begin
  300. mysql_info:=mysql^.info
  301. end;
  302. Function mysql_reload(mysql : PMYSQL) : Longint;
  303. begin
  304. mysql_reload:=mysql_refresh(mysql,REFRESH_GRANT)
  305. end;
  306. Function mysql_thread_id(mysql : PMysql) : Cardinal;
  307. begin
  308. mysql_thread_id:=mysql^.thread_id
  309. end;
  310. end.
  311. {
  312. $Log$
  313. Revision 1.1 2004-09-30 19:34:47 michael
  314. + Split everything in version 3 and version 4
  315. Revision 1.1 2004/09/28 18:38:23 michael
  316. + Moved to subdir, switching to version 4.0
  317. Revision 1.6 2004/08/05 10:36:26 olle
  318. + added, on unixes, $linklib mysqlclient
  319. Revision 1.5 2004/03/29 18:16:02 florian
  320. + darwin support
  321. Revision 1.4 2002/09/10 19:44:28 michael
  322. + Changed stdcall to appropriate OS calling declaration
  323. Revision 1.3 2002/09/07 15:42:52 peter
  324. * old logs removed and tabs fixed
  325. Revision 1.2 2002/08/26 17:52:31 michael
  326. + Upgraded to 3.23
  327. }