odbcsql.pp 57 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614
  1. unit odbcsql;
  2. {$ifndef fpc}
  3. {$I mODBC.INC}
  4. {$else}
  5. {$mode objfpc}
  6. {$h+}
  7. {$define odbcver3}
  8. {$endif}
  9. interface
  10. uses sysutils;
  11. (* DATA TYPES CORRESPONDENCE
  12. BDE fields ODBC types
  13. ---------- ------------------
  14. ftBlob SQL_BINARY
  15. ftBoolean SQL_BIT
  16. ftDate SQL_TYPE_DATE
  17. ftTime SQL_TYPE_TIME
  18. ftDateTime SQL_TYPE_TIMESTAMP
  19. ftInteger SQL_INTEGER
  20. ftSmallint SQL_SMALLINT
  21. ftFloat SQL_DOUBLE
  22. ftString SQL_CHAR
  23. ftMemo SQL_BINARY // SQL_VARCHAR
  24. *)
  25. type
  26. SQLCHAR = Char;
  27. SQLSMALLINT = smallint;
  28. SQLUSMALLINT = Word;
  29. SQLRETURN = SQLSMALLINT;
  30. SQLHANDLE = LongInt;
  31. SQLHENV = SQLHANDLE;
  32. SQLHDBC = SQLHANDLE;
  33. SQLHSTMT = SQLHANDLE;
  34. SQLINTEGER = LongInt;
  35. SQLUINTEGER = Cardinal;
  36. SQLPOINTER = Pointer;
  37. SQLREAL = real;
  38. SQLDOUBLE = Double;
  39. SQLFLOAT = Double;
  40. PSQLCHAR = PChar;
  41. PSQLINTEGER = ^SQLINTEGER;
  42. PSQLUINTEGER = ^SQLUINTEGER;
  43. PSQLSMALLINT = ^SQLSMALLINT;
  44. PSQLUSMALLINT = ^SQLUSMALLINT;
  45. PSQLREAL = ^SQLREAL;
  46. PSQLDOUBLE = ^SQLDOUBLE;
  47. PSQLFLOAT = ^SQLFLOAT;
  48. PSQLHandle = ^SQLHANDLE;
  49. const
  50. { SQL data type codes }
  51. SQL_UNKNOWN_TYPE = 0;
  52. SQL_LONGVARCHAR =(-1);
  53. SQL_BINARY =(-2);
  54. SQL_VARBINARY =(-3);
  55. SQL_LONGVARBINARY =(-4);
  56. SQL_BIGINT =(-5);
  57. SQL_TINYINT =(-6);
  58. SQL_BIT =(-7);
  59. SQL_WCHAR =(-8);
  60. SQL_WVARCHAR =(-9);
  61. SQL_WLONGVARCHAR =(-10);
  62. SQL_CHAR = 1;
  63. SQL_NUMERIC = 2;
  64. SQL_DECIMAL = 3;
  65. SQL_INTEGER = 4;
  66. SQL_SMALLINT = 5;
  67. SQL_FLOAT = 6;
  68. SQL_REAL = 7;
  69. SQL_DOUBLE = 8;
  70. {$ifdef ODBCVER3}
  71. SQL_DATETIME = 9;
  72. {$endif}
  73. SQL_VARCHAR = 12;
  74. SQL_C_LONG = SQL_INTEGER;
  75. {$ifdef ODBCVER3}
  76. SQL_TYPE_DATE = 91;
  77. SQL_TYPE_TIME = 92;
  78. SQL_TYPE_TIMESTAMP= 93;
  79. {$endif}
  80. {ODBC2}
  81. SQL_DATE = 9;
  82. SQL_TIME = 10;
  83. SQL_TIMESTAMP = 11;
  84. {end of Odbc2}
  85. SQL_NO_TOTAL = -4;
  86. type
  87. SQL_DATE_STRUCT = packed record
  88. Year : SQLSMALLINT;
  89. Month : SQLUSMALLINT;
  90. Day : SQLUSMALLINT;
  91. end;
  92. PSQL_DATE_STRUCT = ^SQL_DATE_STRUCT;
  93. SQL_TIME_STRUCT = packed record
  94. Hour : SQLUSMALLINT;
  95. Minute : SQLUSMALLINT;
  96. Second : SQLUSMALLINT;
  97. end;
  98. PSQL_TIME_STRUCT = ^SQL_TIME_STRUCT;
  99. SQL_TIMESTAMP_STRUCT = packed record
  100. Year : SQLUSMALLINT;
  101. Month : SQLUSMALLINT;
  102. Day : SQLUSMALLINT;
  103. Hour : SQLUSMALLINT;
  104. Minute : SQLUSMALLINT;
  105. Second : SQLUSMALLINT;
  106. Fraction : SQLUINTEGER;
  107. end;
  108. PSQL_TIMESTAMP_STRUCT = ^SQL_TIMESTAMP_STRUCT;
  109. const
  110. SQL_NAME_LEN = 128;
  111. SQL_OV_ODBC3 = 3;
  112. SQL_OV_ODBC2 = 2;
  113. SQL_ATTR_ODBC_VERSION = 200;
  114. { Options for SQLDriverConnect }
  115. SQL_DRIVER_NOPROMPT = 0;
  116. SQL_DRIVER_COMPLETE = 1;
  117. SQL_DRIVER_PROMPT = 2;
  118. SQL_DRIVER_COMPLETE_REQUIRED = 3;
  119. { whether an attribute is a pointer or not }
  120. SQL_IS_POINTER = (-4);
  121. SQL_IS_UINTEGER = (-5);
  122. SQL_IS_INTEGER = (-6);
  123. SQL_IS_USMALLINT = (-7);
  124. SQL_IS_SMALLINT = (-8);
  125. { SQLExtendedFetch "fFetchType" values }
  126. SQL_FETCH_BOOKMARK = 8;
  127. SQL_SCROLL_OPTIONS = 44;
  128. { SQL_USE_BOOKMARKS options }
  129. SQL_UB_OFF = 0;
  130. SQL_UB_ON = 1;
  131. SQL_UB_DEFAULT = SQL_UB_OFF;
  132. SQL_UB_FIXED = SQL_UB_ON;
  133. SQL_UB_VARIABLE = 2;
  134. { SQL_SCROLL_OPTIONS masks }
  135. SQL_SO_FORWARD_ONLY = $01;
  136. SQL_SO_KEYSET_DRIVEN = $02;
  137. SQL_SO_DYNAMIC = $04;
  138. SQL_SO_MIXED = $08;
  139. SQL_SO_STATIC = $10;
  140. SQL_BOOKMARK_PERSISTENCE = 82;
  141. SQL_STATIC_SENSITIVITY = 83;
  142. { SQL_BOOKMARK_PERSISTENCE values }
  143. SQL_BP_CLOSE = $01;
  144. SQL_BP_DELETE = $02;
  145. SQL_BP_DROP = $04;
  146. SQL_BP_TRANSACTION = $08;
  147. SQL_BP_UPDATE = $10;
  148. SQL_BP_OTHER_HSTMT = $20;
  149. SQL_BP_SCROLL = $40;
  150. SQL_DYNAMIC_CURSOR_ATTRIBUTES1 = 144;
  151. SQL_DYNAMIC_CURSOR_ATTRIBUTES2 = 145;
  152. SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES1 = 146;
  153. SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2 = 147;
  154. SQL_INDEX_KEYWORDS = 148;
  155. SQL_INFO_SCHEMA_VIEWS = 149;
  156. SQL_KEYSET_CURSOR_ATTRIBUTES1 = 150;
  157. SQL_KEYSET_CURSOR_ATTRIBUTES2 = 151;
  158. SQL_STATIC_CURSOR_ATTRIBUTES1 = 167;
  159. SQL_STATIC_CURSOR_ATTRIBUTES2 = 168;
  160. { supported SQLFetchScroll FetchOrientation's }
  161. SQL_CA1_NEXT = 1;
  162. SQL_CA1_ABSOLUTE = 2;
  163. SQL_CA1_RELATIVE = 4;
  164. SQL_CA1_BOOKMARK = 8;
  165. { supported SQLSetPos LockType's }
  166. SQL_CA1_LOCK_NO_CHANGE= $40;
  167. SQL_CA1_LOCK_EXCLUSIVE= $80;
  168. SQL_CA1_LOCK_UNLOCK =$100;
  169. { supported SQLSetPos Operations }
  170. SQL_CA1_POS_POSITION = $200;
  171. SQL_CA1_POS_UPDATE = $400;
  172. SQL_CA1_POS_DELETE = $800;
  173. SQL_CA1_POS_REFRESH =$1000;
  174. { positioned updates and deletes }
  175. SQL_CA1_POSITIONED_UPDATE=$2000;
  176. SQL_CA1_POSITIONED_DELETE=$4000;
  177. SQL_CA1_SELECT_FOR_UPDATE=$8000;
  178. { supported SQLBulkOperations operations }
  179. SQL_CA1_BULK_ADD =$10000;
  180. SQL_CA1_BULK_UPDATE_BY_BOOKMARK =$20000;
  181. SQL_CA1_BULK_DELETE_BY_BOOKMARK =$40000;
  182. SQL_CA1_BULK_FETCH_BY_BOOKMARK =$80000;
  183. { supported values for SQL_ATTR_SCROLL_CONCURRENCY }
  184. SQL_CA2_READ_ONLY_CONCURRENCY = 1;
  185. SQL_CA2_LOCK_CONCURRENCY = 2;
  186. SQL_CA2_OPT_ROWVER_CONCURRENCY= 4;
  187. SQL_CA2_OPT_VALUES_CONCURRENCY= 8;
  188. { sensitivity of the cursor to its own inserts, deletes, and updates }
  189. SQL_CA2_SENSITIVITY_ADDITIONS =$10;
  190. SQL_CA2_SENSITIVITY_DELETIONS =$20;
  191. SQL_CA2_SENSITIVITY_UPDATES =$40;
  192. { semantics of SQL_ATTR_MAX_ROWS }
  193. SQL_CA2_MAX_ROWS_SELECT = $80;
  194. SQL_CA2_MAX_ROWS_INSERT =$100;
  195. SQL_CA2_MAX_ROWS_DELETE =$200;
  196. SQL_CA2_MAX_ROWS_UPDATE =$400;
  197. SQL_CA2_MAX_ROWS_CATALOG =$800;
  198. SQL_CA2_MAX_ROWS_AFFECTS_ALL =(SQL_CA2_MAX_ROWS_SELECT or
  199. SQL_CA2_MAX_ROWS_INSERT or SQL_CA2_MAX_ROWS_DELETE or
  200. SQL_CA2_MAX_ROWS_UPDATE or SQL_CA2_MAX_ROWS_CATALOG);
  201. { semantics of SQL_DIAG_CURSOR_ROW_COUNT }
  202. SQL_CA2_CRC_EXACT = $1000;
  203. SQL_CA2_CRC_APPROXIMATE = $2000;
  204. { the kinds of positioned statements that can be simulated }
  205. SQL_CA2_SIMULATE_NON_UNIQUE = $4000;
  206. SQL_CA2_SIMULATE_TRY_UNIQUE = $8000;
  207. SQL_CA2_SIMULATE_UNIQUE =$10000;
  208. { Operations in SQLBulkOperations }
  209. SQL_ADD = 4;
  210. SQL_SETPOS_MAX_OPTION_VALUE = SQL_ADD;
  211. SQL_UPDATE_BY_BOOKMARK = 5;
  212. SQL_DELETE_BY_BOOKMARK = 6;
  213. SQL_FETCH_BY_BOOKMARK = 7;
  214. { Operations in SQLSetPos }
  215. SQL_POSITION = 0;
  216. SQL_REFRESH = 1;
  217. SQL_UPDATE = 2;
  218. SQL_DELETE = 3;
  219. { Lock options in SQLSetPos }
  220. SQL_LOCK_NO_CHANGE = 0;
  221. SQL_LOCK_EXCLUSIVE = 1;
  222. SQL_LOCK_UNLOCK = 2;
  223. { SQLExtendedFetch "rgfRowStatus" element values }
  224. SQL_ROW_SUCCESS = 0;
  225. SQL_ROW_DELETED = 1;
  226. SQL_ROW_UPDATED = 2;
  227. SQL_ROW_NOROW = 3;
  228. SQL_ROW_ADDED = 4;
  229. SQL_ROW_ERROR = 5;
  230. SQL_ROW_SUCCESS_WITH_INFO = 6;
  231. SQL_ROW_PROCEED = 0;
  232. SQL_ROW_IGNORE = 1;
  233. SQL_MAX_DSN_LENGTH = 32; { maximum data source name size }
  234. SQL_MAX_OPTION_STRING_LENGTH = 256;
  235. SQL_ODBC_CURSORS = 110;
  236. SQL_ATTR_ODBC_CURSORS = SQL_ODBC_CURSORS;
  237. { SQL_ODBC_CURSORS options }
  238. SQL_CUR_USE_IF_NEEDED = 0;
  239. SQL_CUR_USE_ODBC = 1;
  240. SQL_CUR_USE_DRIVER = 2;
  241. SQL_CUR_DEFAULT = SQL_CUR_USE_DRIVER;
  242. SQL_PARAM_TYPE_UNKNOWN = 0;
  243. SQL_PARAM_INPUT = 1;
  244. SQL_PARAM_INPUT_OUTPUT = 2;
  245. SQL_RESULT_COL = 3;
  246. SQL_PARAM_OUTPUT = 4;
  247. SQL_RETURN_VALUE = 5;
  248. { special length/indicator values }
  249. SQL_NULL_DATA = (-1);
  250. SQL_DATA_AT_EXEC = (-2);
  251. SQL_SUCCESS = 0;
  252. SQL_SUCCESS_WITH_INFO = 1;
  253. SQL_NO_DATA = 100;
  254. SQL_ERROR = (-1);
  255. SQL_INVALID_HANDLE =(-2);
  256. SQL_STILL_EXECUTING = 2;
  257. SQL_NEED_DATA = 99;
  258. { flags for null-terminated string }
  259. SQL_NTS = (-3);
  260. { maximum message length }
  261. SQL_MAX_MESSAGE_LENGTH = 512;
  262. { date/time length constants }
  263. {$ifdef ODBCVER3}
  264. SQL_DATE_LEN = 10;
  265. SQL_TIME_LEN = 8; { add P+1 if precision is nonzero }
  266. SQL_TIMESTAMP_LEN = 19; { add P+1 if precision is nonzero }
  267. {$endif}
  268. { handle type identifiers }
  269. SQL_HANDLE_ENV = 1;
  270. SQL_HANDLE_DBC = 2;
  271. SQL_HANDLE_STMT = 3;
  272. SQL_HANDLE_DESC = 4;
  273. {$ifdef ODBCVER3}
  274. { environment attribute }
  275. SQL_ATTR_OUTPUT_NTS = 10001;
  276. { connection attributes }
  277. SQL_ATTR_AUTO_IPD = 10001;
  278. SQL_ATTR_METADATA_ID = 10014;
  279. {$endif} { ODBCVER >= 0x0300 }
  280. { statement attributes }
  281. SQL_ATTR_APP_ROW_DESC = 10010;
  282. SQL_ATTR_APP_PARAM_DESC = 10011;
  283. SQL_ATTR_IMP_ROW_DESC = 10012;
  284. SQL_ATTR_IMP_PARAM_DESC = 10013;
  285. SQL_ATTR_CURSOR_SCROLLABLE = (-1);
  286. SQL_ATTR_CURSOR_SENSITIVITY = (-2);
  287. SQL_QUERY_TIMEOUT =0;
  288. SQL_MAX_ROWS =1;
  289. SQL_NOSCAN =2;
  290. SQL_MAX_LENGTH =3;
  291. SQL_ASYNC_ENABLE =4; // same as SQL_ATTR_ASYNC_ENABLE */
  292. SQL_BIND_TYPE =5;
  293. SQL_CURSOR_TYPE = 6;
  294. SQL_CONCURRENCY = 7;
  295. SQL_KEYSET_SIZE =8;
  296. SQL_ROWSET_SIZE =9;
  297. SQL_SIMULATE_CURSOR =10;
  298. SQL_RETRIEVE_DATA =11;
  299. SQL_USE_BOOKMARKS =12;
  300. SQL_GET_BOOKMARK =13; // GetStmtOption Only */
  301. SQL_ROW_NUMBER = 14; // GetStmtOption Only */
  302. SQL_ATTR_CURSOR_TYPE = SQL_CURSOR_TYPE;
  303. SQL_ATTR_CONCURRENCY = SQL_CONCURRENCY;
  304. SQL_ATTR_FETCH_BOOKMARK_PTR = 16;
  305. SQL_ATTR_ROW_STATUS_PTR = 25;
  306. SQL_ATTR_ROWS_FETCHED_PTR = 26;
  307. SQL_AUTOCOMMIT = 102;
  308. SQL_ATTR_AUTOCOMMIT = SQL_AUTOCOMMIT;
  309. SQL_ATTR_ROW_NUMBER = SQL_ROW_NUMBER;
  310. SQL_TXN_ISOLATION = 108;
  311. SQL_ATTR_TXN_ISOLATION = SQL_TXN_ISOLATION;
  312. SQL_ATTR_MAX_ROWS = SQL_MAX_ROWS;
  313. SQL_ATTR_USE_BOOKMARKS = SQL_USE_BOOKMARKS;
  314. //* connection attributes */
  315. SQL_ACCESS_MODE =101;
  316. // SQL_AUTOCOMMIT =102;
  317. SQL_LOGIN_TIMEOUT =103;
  318. SQL_OPT_TRACE =104;
  319. SQL_OPT_TRACEFILE =105;
  320. SQL_TRANSLATE_DLL =106;
  321. SQL_TRANSLATE_OPTION =107;
  322. // SQL_TXN_ISOLATION =108;
  323. SQL_CURRENT_QUALIFIER =109;
  324. // SQL_ODBC_CURSORS =110;
  325. SQL_QUIET_MODE =111;
  326. SQL_PACKET_SIZE =112;
  327. //* connection attributes with new names */
  328. SQL_ATTR_ACCESS_MODE =SQL_ACCESS_MODE;
  329. // SQL_ATTR_AUTOCOMMIT =SQL_AUTOCOMMIT;
  330. SQL_ATTR_CONNECTION_DEAD =1209; //* GetConnectAttr only */
  331. SQL_ATTR_CONNECTION_TIMEOUT =113;
  332. SQL_ATTR_CURRENT_CATALOG =SQL_CURRENT_QUALIFIER;
  333. SQL_ATTR_DISCONNECT_BEHAVIOR=114;
  334. SQL_ATTR_ENLIST_IN_DTC =1207;
  335. SQL_ATTR_ENLIST_IN_XA =1208;
  336. SQL_ATTR_LOGIN_TIMEOUT =SQL_LOGIN_TIMEOUT;
  337. // SQL_ATTR_ODBC_CURSORS =SQL_ODBC_CURSORS;
  338. SQL_ATTR_PACKET_SIZE =SQL_PACKET_SIZE;
  339. SQL_ATTR_QUIET_MODE =SQL_QUIET_MODE;
  340. SQL_ATTR_TRACE =SQL_OPT_TRACE;
  341. SQL_ATTR_TRACEFILE =SQL_OPT_TRACEFILE;
  342. SQL_ATTR_TRANSLATE_LIB =SQL_TRANSLATE_DLL;
  343. SQL_ATTR_TRANSLATE_OPTION =SQL_TRANSLATE_OPTION;
  344. // SQL_ATTR_TXN_ISOLATION =SQL_TXN_ISOLATION;
  345. //* SQL_ACCESS_MODE options */
  346. SQL_MODE_READ_WRITE =0;
  347. SQL_MODE_READ_ONLY =1;
  348. SQL_MODE_DEFAULT =SQL_MODE_READ_WRITE;
  349. //* SQL_AUTOCOMMIT options */
  350. SQL_AUTOCOMMIT_OFF = 0;
  351. SQL_AUTOCOMMIT_ON = 1;
  352. SQL_AUTOCOMMIT_DEFAULT = SQL_AUTOCOMMIT_ON;
  353. { SQL_ATTR_CURSOR_SCROLLABLE values }
  354. SQL_NONSCROLLABLE = 0;
  355. SQL_SCROLLABLE = 1;
  356. { SQL_CURSOR_TYPE options }
  357. SQL_CURSOR_FORWARD_ONLY = 0;
  358. SQL_CURSOR_KEYSET_DRIVEN = 1;
  359. SQL_CURSOR_DYNAMIC = 2;
  360. SQL_CURSOR_STATIC = 3;
  361. SQL_CURSOR_TYPE_DEFAULT = SQL_CURSOR_FORWARD_ONLY;{ Default value }
  362. { SQL_CONCURRENCY options }
  363. SQL_CONCUR_READ_ONLY = 1;
  364. SQL_CONCUR_LOCK = 2;
  365. SQL_CONCUR_ROWVER = 3;
  366. SQL_CONCUR_VALUES = 4;
  367. SQL_CONCUR_DEFAULT = SQL_CONCUR_READ_ONLY; { Default value }
  368. { identifiers of fields in the SQL descriptor }
  369. {$ifdef ODBCVER3}
  370. SQL_DESC_COUNT = 1001;
  371. SQL_DESC_TYPE = 1002;
  372. SQL_DESC_LENGTH = 1003;
  373. SQL_DESC_OCTET_LENGTH_PTR = 1004;
  374. SQL_DESC_PRECISION = 1005;
  375. SQL_DESC_SCALE = 1006;
  376. SQL_DESC_DATETIME_INTERVAL_CODE = 1007;
  377. SQL_DESC_NULLABLE = 1008;
  378. SQL_DESC_INDICATOR_PTR = 1009;
  379. SQL_DESC_DATA_PTR = 1010;
  380. SQL_DESC_NAME = 1011;
  381. SQL_DESC_UNNAMED = 1012;
  382. SQL_DESC_OCTET_LENGTH = 1013;
  383. SQL_DESC_ALLOC_TYPE = 1099;
  384. {$endif}
  385. { identifiers of fields in the diagnostics area }
  386. {$ifdef ODBCVER3}
  387. SQL_DIAG_RETURNCODE = 1;
  388. SQL_DIAG_NUMBER = 2;
  389. SQL_DIAG_ROW_COUNT = 3;
  390. SQL_DIAG_SQLSTATE = 4;
  391. SQL_DIAG_NATIVE = 5;
  392. SQL_DIAG_MESSAGE_TEXT = 6;
  393. SQL_DIAG_DYNAMIC_FUNCTION = 7;
  394. SQL_DIAG_CLASS_ORIGIN = 8;
  395. SQL_DIAG_SUBCLASS_ORIGIN = 9;
  396. SQL_DIAG_CONNECTION_NAME = 10;
  397. SQL_DIAG_SERVER_NAME = 11;
  398. SQL_DIAG_DYNAMIC_FUNCTION_CODE = 12;
  399. {$endif}
  400. { dynamic function codes }
  401. {$ifdef ODBCVER3}
  402. SQL_DIAG_ALTER_TABLE = 4;
  403. SQL_DIAG_CREATE_INDEX = (-1);
  404. SQL_DIAG_CREATE_TABLE = 77;
  405. SQL_DIAG_CREATE_VIEW = 84;
  406. SQL_DIAG_DELETE_WHERE = 19;
  407. SQL_DIAG_DROP_INDEX = (-2);
  408. SQL_DIAG_DROP_TABLE = 32;
  409. SQL_DIAG_DROP_VIEW = 36;
  410. SQL_DIAG_DYNAMIC_DELETE_CURSOR = 38;
  411. SQL_DIAG_DYNAMIC_UPDATE_CURSOR = 81;
  412. SQL_DIAG_GRANT = 48;
  413. SQL_DIAG_INSERT = 50;
  414. SQL_DIAG_REVOKE = 59;
  415. SQL_DIAG_SELECT_CURSOR = 85;
  416. SQL_DIAG_UNKNOWN_STATEMENT = 0;
  417. SQL_DIAG_UPDATE_WHERE = 82;
  418. {$endif} { ODBCVER >= 0x0300 }
  419. SQL_C_DEFAULT = 99;
  420. SQL_UNSIGNED_OFFSET = (-22);
  421. SQL_C_ULONG = (SQL_C_LONG+SQL_UNSIGNED_OFFSET);
  422. SQL_C_BOOKMARK = SQL_C_ULONG;
  423. { Statement attribute values for cursor sensitivity }
  424. {$ifdef ODBCVER3}
  425. SQL_UNSPECIFIED = 0;
  426. SQL_INSENSITIVE = 1;
  427. SQL_SENSITIVE = 2;
  428. {$endif}
  429. { GetTypeInfo() request for all data types }
  430. SQL_ALL_TYPES = 0;
  431. { Default conversion code for SQLBindCol(), SQLBindParam() and SQLGetData() }
  432. {$ifdef ODBCVER3}
  433. SQL_DEFAULT = 99;
  434. {$endif}
  435. { SQLGetData() code indicating that the application row descriptor
  436. specifies the data type }
  437. {$ifdef ODBCVER3}
  438. SQL_ARD_TYPE = (-99);
  439. {$endif}
  440. { SQL date/time type subcodes }
  441. {$ifdef ODBCVER3}
  442. SQL_CODE_DATE = 1;
  443. SQL_CODE_TIME = 2;
  444. SQL_CODE_TIMESTAMP = 3;
  445. {$endif}
  446. { CLI option values }
  447. {$ifdef ODBCVER3}
  448. SQL_FALSE = 0;
  449. SQL_TRUE = 1;
  450. {$endif}
  451. { values of NULLABLE field in descriptor }
  452. SQL_NO_NULLS = 0;
  453. SQL_NULLABLE = 1;
  454. { Value returned by SQLGetTypeInfo() to denote that it is
  455. not known whether or not a data type supports null values. }
  456. SQL_NULLABLE_UNKNOWN = 2;
  457. {
  458. /* Values returned by SQLGetTypeInfo() to show WHERE clause
  459. * supported
  460. #if (ODBCVER >= 0x0300)
  461. #define SQL_PRED_NONE 0
  462. #define SQL_PRED_CHAR 1
  463. #define SQL_PRED_BASIC 2
  464. #endif
  465. /* values of UNNAMED field in descriptor */
  466. #if (ODBCVER >= 0x0300)
  467. #define SQL_NAMED 0
  468. #define SQL_UNNAMED 1
  469. #endif
  470. /* values of ALLOC_TYPE field in descriptor */
  471. #if (ODBCVER >= 0x0300)
  472. #define SQL_DESC_ALLOC_AUTO 1
  473. #define SQL_DESC_ALLOC_USER 2
  474. #endif
  475. }
  476. { FreeStmt() options }
  477. SQL_CLOSE = 0;
  478. SQL_DROP = 1;
  479. SQL_UNBIND = 2;
  480. SQL_RESET_PARAMS = 3;
  481. { Codes used for FetchOrientation in SQLFetchScroll(),
  482. and in SQLDataSources() }
  483. SQL_FETCH_NEXT = 1;
  484. SQL_FETCH_FIRST = 2;
  485. {$ifdef odbcver3}
  486. SQL_FETCH_FIRST_USER = 31;
  487. SQL_FETCH_FIRST_SYSTEM = 32;
  488. {$endif}
  489. { Other codes used for FetchOrientation in SQLFetchScroll() }
  490. SQL_FETCH_LAST = 3;
  491. SQL_FETCH_PRIOR = 4;
  492. SQL_FETCH_ABSOLUTE = 5;
  493. SQL_FETCH_RELATIVE = 6;
  494. {
  495. /* SQLEndTran() options */
  496. #define SQL_COMMIT 0
  497. #define SQL_ROLLBACK 1
  498. /* null handles returned by SQLAllocHandle() */
  499. #define SQL_NULL_HENV 0
  500. #define SQL_NULL_HDBC 0
  501. #define SQL_NULL_HSTMT 0
  502. #if (ODBCVER >= 0x0300)
  503. #define SQL_NULL_HDESC 0
  504. #endif
  505. }
  506. //* null handle used in place of parent handle when allocating HENV */
  507. SQL_NULL_HANDLE = 0;
  508. //* Values that may appear in the result set of SQLSpecialColumns() */
  509. SQL_SCOPE_CURROW = 0;
  510. SQL_SCOPE_TRANSACTION = 1;
  511. SQL_SCOPE_SESSION = 2;
  512. //* Column types and scopes in SQLSpecialColumns. */
  513. SQL_BEST_ROWID = 1;
  514. SQL_ROWVER = 2;
  515. {
  516. #define SQL_PC_UNKNOWN 0
  517. #if (ODBCVER >= 0x0300)
  518. #define SQL_PC_NON_PSEUDO 1
  519. #endif
  520. #define SQL_PC_PSEUDO 2
  521. }
  522. //* Reserved value for the IdentifierType argument of SQLSpecialColumns() */
  523. {$ifdef ODBCVER3}
  524. SQL_ROW_IDENTIFIER = 1;
  525. {$endif}
  526. {
  527. /* Reserved values for UNIQUE argument of SQLStatistics() */
  528. #define SQL_INDEX_UNIQUE 0
  529. #define SQL_INDEX_ALL 1
  530. /* Values that may appear in the result set of SQLStatistics() */
  531. #define SQL_INDEX_CLUSTERED 1
  532. #define SQL_INDEX_HASHED 2
  533. #define SQL_INDEX_OTHER 3
  534. /* Information requested by SQLGetInfo() */
  535. #if (ODBCVER >= 0x0300)
  536. #define SQL_MAX_DRIVER_CONNECTIONS 0
  537. #define SQL_MAXIMUM_DRIVER_CONNECTIONS SQL_MAX_DRIVER_CONNECTIONS
  538. #define SQL_MAX_CONCURRENT_ACTIVITIES 1
  539. #define SQL_MAXIMUM_CONCURRENT_ACTIVITIES SQL_MAX_CONCURRENT_ACTIVITIES
  540. #endif
  541. #define SQL_DATA_SOURCE_NAME 2
  542. #define SQL_FETCH_DIRECTION 8
  543. #define SQL_SERVER_NAME 13
  544. #define SQL_SEARCH_PATTERN_ESCAPE 14
  545. #define SQL_DBMS_NAME 17
  546. #define SQL_DBMS_VER 18
  547. #define SQL_ACCESSIBLE_TABLES 19
  548. #define SQL_ACCESSIBLE_PROCEDURES 20
  549. #define SQL_CURSOR_COMMIT_BEHAVIOR 23
  550. #define SQL_DATA_SOURCE_READ_ONLY 25
  551. #define SQL_DEFAULT_TXN_ISOLATION 26
  552. #define SQL_IDENTIFIER_CASE 28
  553. #define SQL_IDENTIFIER_QUOTE_CHAR 29
  554. #define SQL_MAX_COLUMN_NAME_LEN 30
  555. #define SQL_MAXIMUM_COLUMN_NAME_LENGTH SQL_MAX_COLUMN_NAME_LEN
  556. #define SQL_MAX_CURSOR_NAME_LEN 31
  557. #define SQL_MAXIMUM_CURSOR_NAME_LENGTH SQL_MAX_CURSOR_NAME_LEN
  558. #define SQL_MAX_SCHEMA_NAME_LEN 32
  559. #define SQL_MAXIMUM_SCHEMA_NAME_LENGTH SQL_MAX_SCHEMA_NAME_LEN
  560. #define SQL_MAX_CATALOG_NAME_LEN 34
  561. #define SQL_MAXIMUM_CATALOG_NAME_LENGTH SQL_MAX_CATALOG_NAME_LEN
  562. #define SQL_MAX_TABLE_NAME_LEN 35
  563. }
  564. SQL_SCROLL_CONCURRENCY = 43;
  565. SQL_TXN_CAPABLE = 46;
  566. SQL_TRANSACTION_CAPABLE = SQL_TXN_CAPABLE;
  567. SQL_USER_NAME = 47;
  568. SQL_TXN_ISOLATION_OPTION = 72;
  569. SQL_TRANSACTION_ISOLATION_OPTION = SQL_TXN_ISOLATION_OPTION;
  570. {
  571. #define SQL_INTEGRITY 73
  572. #define SQL_GETDATA_EXTENSIONS 81
  573. #define SQL_NULL_COLLATION 85
  574. #define SQL_ALTER_TABLE 86
  575. #define SQL_ORDER_BY_COLUMNS_IN_SELECT 90
  576. #define SQL_SPECIAL_CHARACTERS 94
  577. #define SQL_MAX_COLUMNS_IN_GROUP_BY 97
  578. #define SQL_MAXIMUM_COLUMNS_IN_GROUP_BY SQL_MAX_COLUMNS_IN_GROUP_BY
  579. #define SQL_MAX_COLUMNS_IN_INDEX 98
  580. #define SQL_MAXIMUM_COLUMNS_IN_INDEX SQL_MAX_COLUMNS_IN_INDEX
  581. #define SQL_MAX_COLUMNS_IN_ORDER_BY 99
  582. #define SQL_MAXIMUM_COLUMNS_IN_ORDER_BY SQL_MAX_COLUMNS_IN_ORDER_BY
  583. #define SQL_MAX_COLUMNS_IN_SELECT 100
  584. #define SQL_MAXIMUM_COLUMNS_IN_SELECT SQL_MAX_COLUMNS_IN_SELECT
  585. #define SQL_MAX_COLUMNS_IN_TABLE 101
  586. #define SQL_MAX_INDEX_SIZE 102
  587. #define SQL_MAXIMUM_INDEX_SIZE SQL_MAX_INDEX_SIZE
  588. #define SQL_MAX_ROW_SIZE 104
  589. #define SQL_MAXIMUM_ROW_SIZE SQL_MAX_ROW_SIZE
  590. #define SQL_MAX_STATEMENT_LEN 105
  591. #define SQL_MAXIMUM_STATEMENT_LENGTH SQL_MAX_STATEMENT_LEN
  592. #define SQL_MAX_TABLES_IN_SELECT 106
  593. #define SQL_MAXIMUM_TABLES_IN_SELECT SQL_MAX_TABLES_IN_SELECT
  594. #define SQL_MAX_USER_NAME_LEN 107
  595. #define SQL_MAXIMUM_USER_NAME_LENGTH SQL_MAX_USER_NAME_LEN}
  596. {$ifdef ODBCVER3}
  597. SQL_OJ_CAPABILITIES = 115;
  598. SQL_OUTER_JOIN_CAPABILITIES = SQL_OJ_CAPABILITIES;
  599. {$endif} { ODBCVER >= 0x0300 }
  600. {$ifdef ODBCVER3}
  601. SQL_XOPEN_CLI_YEAR = 10000;
  602. SQL_CURSOR_SENSITIVITY = 10001;
  603. SQL_DESCRIBE_PARAMETER = 10002;
  604. SQL_CATALOG_NAME = 10003;
  605. SQL_COLLATION_SEQ = 10004;
  606. SQL_MAX_IDENTIFIER_LEN = 10005;
  607. SQL_MAXIMUM_IDENTIFIER_LENGTH = SQL_MAX_IDENTIFIER_LEN;
  608. {$endif} { ODBCVER >= 0x0300 }
  609. {/* SQL_ALTER_TABLE bitmasks */
  610. #if (ODBCVER >= 0x0200)
  611. #define SQL_AT_ADD_COLUMN 0x00000001L
  612. #define SQL_AT_DROP_COLUMN 0x00000002L
  613. #endif /* ODBCVER >= 0x0200 */
  614. #if (ODBCVER >= 0x0300)
  615. #define SQL_AT_ADD_CONSTRAINT 0x00000008L
  616. /* The following bitmasks are ODBC extensions and defined in sqlext.h
  617. *#define SQL_AT_COLUMN_SINGLE 0x00000020L
  618. *#define SQL_AT_ADD_COLUMN_DEFAULT 0x00000040L
  619. *#define SQL_AT_ADD_COLUMN_COLLATION 0x00000080L
  620. *#define SQL_AT_SET_COLUMN_DEFAULT 0x00000100L
  621. *#define SQL_AT_DROP_COLUMN_DEFAULT 0x00000200L
  622. *#define SQL_AT_DROP_COLUMN_CASCADE 0x00000400L
  623. *#define SQL_AT_DROP_COLUMN_RESTRICT 0x00000800L
  624. *#define SQL_AT_ADD_TABLE_CONSTRAINT 0x00001000L
  625. *#define SQL_AT_DROP_TABLE_CONSTRAINT_CASCADE 0x00002000L
  626. *#define SQL_AT_DROP_TABLE_CONSTRAINT_RESTRICT 0x00004000L
  627. *#define SQL_AT_CONSTRAINT_NAME_DEFINITION 0x00008000L
  628. *#define SQL_AT_CONSTRAINT_INITIALLY_DEFERRED 0x00010000L
  629. *#define SQL_AT_CONSTRAINT_INITIALLY_IMMEDIATE 0x00020000L
  630. *#define SQL_AT_CONSTRAINT_DEFERRABLE 0x00040000L
  631. *#define SQL_AT_CONSTRAINT_NON_DEFERRABLE 0x00080000L
  632. #endif /* ODBCVER >= 0x0300 */
  633. /* SQL_ASYNC_MODE values */
  634. #if (ODBCVER >= 0x0300)
  635. #define SQL_AM_NONE 0
  636. #define SQL_AM_CONNECTION 1
  637. #define SQL_AM_STATEMENT 2
  638. #endif
  639. /* SQL_CURSOR_COMMIT_BEHAVIOR values */
  640. #define SQL_CB_DELETE 0
  641. #define SQL_CB_CLOSE 1
  642. #define SQL_CB_PRESERVE 2
  643. /* SQL_FETCH_DIRECTION bitmasks */
  644. #define SQL_FD_FETCH_NEXT 0x00000001L
  645. #define SQL_FD_FETCH_FIRST 0x00000002L
  646. #define SQL_FD_FETCH_LAST 0x00000004L
  647. #define SQL_FD_FETCH_PRIOR 0x00000008L
  648. #define SQL_FD_FETCH_ABSOLUTE 0x00000010L
  649. #define SQL_FD_FETCH_RELATIVE 0x00000020L
  650. /* SQL_GETDATA_EXTENSIONS bitmasks */
  651. #define SQL_GD_ANY_COLUMN 0x00000001L
  652. #define SQL_GD_ANY_ORDER 0x00000002L
  653. /* SQL_IDENTIFIER_CASE values */
  654. #define SQL_IC_UPPER 1
  655. #define SQL_IC_LOWER 2
  656. #define SQL_IC_SENSITIVE 3
  657. #define SQL_IC_MIXED 4
  658. /* SQL_OJ_CAPABILITIES bitmasks */
  659. /* NB: this means 'outer join', not what you may be thinking */
  660. #if (ODBCVER >= 0x0201)
  661. #define SQL_OJ_LEFT 0x00000001L
  662. #define SQL_OJ_RIGHT 0x00000002L
  663. #define SQL_OJ_FULL 0x00000004L
  664. #define SQL_OJ_NESTED 0x00000008L
  665. #define SQL_OJ_NOT_ORDERED 0x00000010L
  666. #define SQL_OJ_INNER 0x00000020L
  667. #define SQL_OJ_ALL_COMPARISON_OPS 0x00000040L
  668. #endif
  669. }
  670. { SQL_SCROLL_CONCURRENCY bitmasks }
  671. SQL_SCCO_READ_ONLY = 1;
  672. SQL_SCCO_LOCK = 2;
  673. SQL_SCCO_OPT_ROWVER = 4;
  674. SQL_SCCO_OPT_VALUES = 8;
  675. //* SQL_TXN_CAPABLE values */
  676. SQL_TC_NONE = 0;
  677. SQL_TC_DML = 1;
  678. SQL_TC_ALL = 2;
  679. SQL_TC_DDL_COMMIT = 3;
  680. SQL_TC_DDL_IGNORE = 4;
  681. //* SQL_TXN_ISOLATION_OPTION bitmasks */
  682. SQL_TXN_READ_UNCOMMITTED = 1;
  683. SQL_TRANSACTION_READ_UNCOMMITTED = SQL_TXN_READ_UNCOMMITTED;
  684. SQL_TXN_READ_COMMITTED = 2;
  685. SQL_TRANSACTION_READ_COMMITTED = SQL_TXN_READ_COMMITTED;
  686. SQL_TXN_REPEATABLE_READ = 4;
  687. SQL_TRANSACTION_REPEATABLE_READ = SQL_TXN_REPEATABLE_READ;
  688. SQL_TXN_SERIALIZABLE = 8;
  689. SQL_TRANSACTION_SERIALIZABLE = SQL_TXN_SERIALIZABLE;
  690. {
  691. /* SQL_NULL_COLLATION values */
  692. #define SQL_NC_HIGH 0
  693. #define SQL_NC_LOW 1
  694. }
  695. { SQL_STATIC_SENSITIVITY values }
  696. SQL_SS_ADDITIONS = 1;
  697. SQL_SS_DELETIONS = 2;
  698. SQL_SS_UPDATES = 4;
  699. { SQLColAttributes defines }
  700. SQL_COLUMN_COUNT = 0;
  701. SQL_COLUMN_NAME = 1;
  702. SQL_COLUMN_TYPE = 2;
  703. SQL_COLUMN_LENGTH = 3;
  704. SQL_COLUMN_PRECISION = 4;
  705. SQL_COLUMN_SCALE = 5;
  706. SQL_COLUMN_DISPLAY_SIZE = 6;
  707. SQL_COLUMN_NULLABLE = 7;
  708. SQL_COLUMN_UNSIGNED = 8;
  709. SQL_COLUMN_MONEY = 9;
  710. SQL_COLUMN_UPDATABLE = 10;
  711. SQL_COLUMN_AUTO_INCREMENT = 11;
  712. SQL_COLUMN_CASE_SENSITIVE = 12;
  713. SQL_COLUMN_SEARCHABLE = 13;
  714. SQL_COLUMN_TYPE_NAME = 14;
  715. SQL_COLUMN_TABLE_NAME = 15;
  716. SQL_COLUMN_OWNER_NAME = 16;
  717. SQL_COLUMN_QUALIFIER_NAME = 17;
  718. SQL_COLUMN_LABEL = 18;
  719. SQL_COLATT_OPT_MAX = SQL_COLUMN_LABEL;
  720. {$ifdef ODBCVER3}
  721. SQL_COLUMN_DRIVER_START = 1000;
  722. {$endif} { ODBCVER >= 0x0300 }
  723. SQL_DESC_AUTO_UNIQUE_VALUE = SQL_COLUMN_AUTO_INCREMENT;
  724. SQL_DESC_BASE_COLUMN_NAME = 22;
  725. SQL_DESC_BASE_TABLE_NAME = 23;
  726. SQL_DESC_TABLE_NAME = SQL_COLUMN_TABLE_NAME;
  727. //* SQLEndTran() options */
  728. SQL_COMMIT = 0;
  729. SQL_ROLLBACK = 1;
  730. SQL_ATTR_ROW_ARRAY_SIZE = 27;
  731. //* SQLConfigDataSource() options */
  732. ODBC_ADD_DSN = 1;
  733. ODBC_CONFIG_DSN = 2;
  734. ODBC_REMOVE_DSN = 3;
  735. ODBC_ADD_SYS_DSN = 4;
  736. ODBC_CONFIG_SYS_DSN = 5;
  737. ODBC_REMOVE_SYS_DSN = 6;
  738. {$ifdef DYNLOADINGODBC}
  739. type tSQLAllocHandle =function(HandleType: SQLSMALLINT;
  740. InputHandle:SQLHANDLE;Var OutputHandlePtr: SQLHANDLE):SQLRETURN;stdcall;
  741. type tSQLSetEnvAttr=function (EnvironmentHandle:SQLHENV;
  742. Attribute:SQLINTEGER;Value:SQLPOINTER;
  743. StringLength:SQLINTEGER):SQLRETURN;stdcall;
  744. type TSQLFreeHandle=function (HandleType:SQLSMALLINT;
  745. Handle:SQLHANDLE):SQLRETURN;stdcall;
  746. type TSQLGetDiagRec=function (HandleType:SQLSMALLINT;
  747. Handle:SQLHANDLE;RecNumber:SQLSMALLINT;
  748. Sqlstate:PSQLCHAR;var NativeError:SQLINTEGER;
  749. MessageText:PSQLCHAR;BufferLength:SQLSMALLINT;
  750. var TextLength:SQLSMALLINT ):SQLRETURN;stdcall;
  751. type TSQLConnect=function (ConnectionHandle:SQLHDBC;
  752. ServerName:PSQLCHAR;NameLength1:SQLSMALLINT;
  753. UserName:PSQLCHAR;NameLength2:SQLSMALLINT;
  754. Authentication:PSQLCHAR;NameLength3:SQLSMALLINT):SQLRETURN;stdcall;
  755. type TSQLDisconnect=function(ConnectionHandle:SQLHDBC):SQLRETURN;stdcall;
  756. type TSQLDriverConnect=function (hdbc: SQLHDBC;
  757. hwnd: Integer;szCsin: PChar;
  758. szCLen: SQLSMALLINT;szCsout: PChar;
  759. cbCSMax: SQLSMALLINT;Var cbCsOut: SQLSMALLINT;
  760. f: Integer):SQLRETURN;stdcall;
  761. type TSQLExecDirect=function (StatementHandle:SQLHSTMT;
  762. StatementText:PSQLCHAR;TextLength:SQLINTEGER):SQLRETURN;stdcall;
  763. type TSQLPrepare=function (StatementHandle:SQLHSTMT;
  764. StatementText:PSQLCHAR;TextLength:SQLINTEGER):SQLRETURN;stdcall;
  765. type TSQLCloseCursor=function (StatementHandle:SQLHSTMT):SQLRETURN;stdcall;
  766. type TSQLExecute=function (StatementHandle:SQLHSTMT):SQLRETURN;stdcall;
  767. type TSQLFetch=function (StatementHandle:SQLHSTMT):SQLRETURN;stdcall;
  768. type TSQLNumResultCols=function (StatementHandle:SQLHSTMT;
  769. var ColumnCount:SQLSMALLINT):SQLRETURN;stdcall;
  770. type TSQLDescribeCol=function (StatementHandle:SQLHSTMT;
  771. ColumnNumber:SQLUSMALLINT;ColumnName:PSQLCHAR;
  772. BufferLength:SQLSMALLINT;var NameLength:SQLSMALLINT;
  773. var DataType:SQLSMALLINT;var ColumnSize:SQLUINTEGER;
  774. var DecimalDigits:SQLSMALLINT;var Nullable:SQLSMALLINT):SQLRETURN;stdcall;
  775. type TSQLFetchScroll=function (StatementHandle:SQLHSTMT;
  776. FetchOrientation:SQLSMALLINT;FetchOffset:SQLINTEGER):SQLRETURN;stdcall;
  777. type TSQLExtendedFetch=function (hstmt:SQLHSTMT;
  778. fFetchType:SQLUSMALLINT;irow:SQLINTEGER;
  779. pcrow:PSQLUINTEGER;rgfRowStatus:PSQLUSMALLINT):SQLRETURN;stdcall;
  780. type TSQLGetData=function (StatementHandle:SQLHSTMT;
  781. ColumnNumber:SQLUSMALLINT;TargetType:SQLSMALLINT;
  782. TargetValue:SQLPOINTER;BufferLength:SQLINTEGER;
  783. StrLen_or_Ind:PSQLINTEGER):SQLRETURN;stdcall;
  784. type TSQLSetStmtAttr=function (StatementHandle:SQLHSTMT;
  785. Attribute:SQLINTEGER;Value:SQLPOINTER;
  786. StringLength:SQLINTEGER):SQLRETURN;stdcall;
  787. type TSQLGetStmtAttr=function (StatementHandle:SQLHSTMT;
  788. Attribute:SQLINTEGER;Value:SQLPOINTER;
  789. BufferLength:SQLINTEGER;StringLength:PSQLINTEGER):SQLRETURN;stdcall;
  790. type tSQLGetInfo=function (ConnectionHandle:SQLHDBC;
  791. InfoType:SQLUSMALLINT;InfoValue:SQLPOINTER;
  792. BufferLength:SQLSMALLINT;StringLength:PSQLSMALLINT):SQLRETURN;stdcall;
  793. type TSQLBulkOperations=function (StatementHandle: SQLHSTMT;
  794. Operation:SQLSMALLINT):SQLRETURN;stdcall;
  795. type TSQLPutData=function (StatementHandle:SQLHSTMT;
  796. Data:SQLPOINTER;StrLen_or_Ind:SQLINTEGER):SQLRETURN;stdcall;
  797. type TSQLBindCol=function (StatementHandle:SQLHSTMT;
  798. ColumnNumber:SQLUSMALLINT;TargetType:SQLSMALLINT;
  799. TargetValue:SQLPOINTER;BufferLength:SQLINTEGER;
  800. StrLen_or_Ind:PSQLINTEGER):SQLRETURN;stdcall;
  801. type TSQLSetPos=function (hstmt:SQLHSTMT;
  802. irow:SQLUSMALLINT;fOption:SQLUSMALLINT;
  803. fLock:SQLUSMALLINT):SQLRETURN;stdcall;
  804. type TSQLDataSources=function (EnvironmentHandle:SQLHENV;
  805. Direction:SQLUSMALLINT;ServerName:PSQLCHAR;
  806. BufferLength1:SQLSMALLINT;NameLength1:PSQLSMALLINT;
  807. Description:PSQLCHAR;BufferLength2:SQLSMALLINT;
  808. NameLength2:PSQLSMALLINT):SQLRETURN;stdcall;
  809. type TSQLDrivers=function (EnvironmentHandle:SQLHENV;
  810. Direction:SQLUSMALLINT;DriverDescription:PSQLCHAR;
  811. BufferLength1:SQLSMALLINT;DescriptionLength1:PSQLSMALLINT;
  812. DriverAttributes:PSQLCHAR;BufferLength2:SQLSMALLINT;
  813. AttributesLength2:PSQLSMALLINT):SQLRETURN;stdcall;
  814. type TSQLSetConnectAttr=function (ConnectionHandle:SQLHDBC;
  815. Attribute:SQLINTEGER; Value:SQLPOINTER;
  816. StringLength:SQLINTEGER):SQLRETURN;stdcall;
  817. type TSQLGetCursorName=function (StatementHandle:SQLHSTMT;
  818. CursorName:PSQLCHAR; BufferLength:SQLSMALLINT;
  819. NameLength:PSQLSMALLINT):SQLRETURN;stdcall;
  820. type TSQLSetCursorName=function (StatementHandle:SQLHSTMT;
  821. CursorName:PSQLCHAR; NameLength:SQLSMALLINT):SQLRETURN;stdcall;
  822. type TSQLRowCount=function (StatementHandle:SQLHSTMT;
  823. Var RowCount:SQLINTEGER):SQLRETURN;stdcall;
  824. type TSQLBindParameter=function (hstmt:SQLHSTMT;
  825. ipar:SQLUSMALLINT;fParamType:SQLSMALLINT;
  826. fCType:SQLSMALLINT;fSqlType:SQLSMALLINT;
  827. cbColDef:SQLUINTEGER;ibScale:SQLSMALLINT;
  828. rgbValue:SQLPOINTER;cbValueMax:SQLINTEGER;
  829. pcbValue:PSQLINTEGER):SQLRETURN;stdcall;
  830. type TSQLFreeStmt=function (StatementHandle:SQLHSTMT;
  831. Option:SQLUSMALLINT):SQLRETURN;stdcall;
  832. type TSQLColAttribute=function (StatementHandle:SQLHSTMT;
  833. ColumnNumber:SQLUSMALLINT;FieldIdentifier:SQLUSMALLINT;
  834. CharacterAttribute:PSQLCHAR;BufferLength:SQLSMALLINT;
  835. StringLength:PSQLSMALLINT;NumericAttribute:SQLPOINTER):SQLRETURN;stdcall;
  836. type TSQLEndTran=function (HandleType:SQLSMALLINT;
  837. Handle:SQLHANDLE;CompletionType:SQLSMALLINT):SQLRETURN;stdcall;
  838. type TSQLTables=function ( hstmt : SQLHSTMT;
  839. szTableQualifier : PSQLCHAR;cbTableQualifier : SQLSMALLINT;
  840. szTableOwner : PSQLCHAR;cbTableOwner : SQLSMALLINT;
  841. szTableName : PSQLCHAR;cbTableName : SQLSMALLINT;
  842. szTableType : PSQLCHAR;cbTableType : SQLSMALLINT ) : SQLRETURN; stdcall;
  843. type TSQLColumns=function ( hstmt : SQLHSTMT;
  844. szTableQualifier : PSQLCHAR;cbTableQualifier : SQLSMALLINT;
  845. szTableOwner : PSQLCHAR;cbTableOwner : SQLSMALLINT;
  846. szTableName : PSQLCHAR;cbTableName : SQLSMALLINT;
  847. szColumnName : PSQLCHAR;cbColumnName : SQLSMALLINT ) : SQLRETURN; stdcall;
  848. type TSQLSpecialColumns=function (StatementHandle:SQLHSTMT;
  849. IdentifierType:SQLUSMALLINT;CatalogName:PSQLCHAR;
  850. NameLength1:SQLSMALLINT;SchemaName:PSQLCHAR;
  851. NameLength2:SQLSMALLINT;TableName:PSQLCHAR;
  852. NameLength3:SQLSMALLINT;Scope:SQLUSMALLINT;
  853. Nullable:SQLUSMALLINT) : SQLRETURN; stdcall;
  854. type TSQLProcedures=function ( hstmt : SQLHSTMT;
  855. szTableQualifier : PSQLCHAR;cbTableQualifier : SQLSMALLINT;
  856. szTableOwner : PSQLCHAR;cbTableOwner : SQLSMALLINT;
  857. szTableName : PSQLCHAR;cbTableName : SQLSMALLINT ) : SQLRETURN; stdcall;
  858. type TSQLPrimaryKeys=function (hstmt : SQLHSTMT;
  859. CatalogName:PSQLCHAR;NameLength1:SQLSMALLINT;
  860. SchemaName:PSQLCHAR;NameLength2:SQLSMALLINT;
  861. TableName:PSQLCHAR;NameLength3:SQLSMALLINT ):SQLRETURN;stdcall;
  862. type TSQLProcedureColumns = function(hstmt: SQLHSTMT;
  863. CatalogName: PSQLCHAR; NameLength1: SQLSMALLINT;
  864. SchemaName: PSQLCHAR; NameLength2: SQLSMALLINT;
  865. ProcName: PSQLCHAR; NameLength3: SQLSMALLINT;
  866. ColumnName: PSQLCHAR; NameLength4: SQLSMALLINT): SQLRETURN; stdcall;
  867. var SQLAllocHandle:tSQLAllocHandle;
  868. var SQLSetEnvAttr:tSQLSetEnvAttr;
  869. var SQLFreeHandle:tSQLFreeHandle;
  870. var SQLGetInfo:tSQLGetInfo;
  871. var SQLProcedures:TSQLProcedures;
  872. var SQLColumns:TSQLColumns;
  873. var SQLSpecialColumns:TSQLSpecialColumns;
  874. var SQLGetDiagRec:TSQLGetDiagRec;
  875. var SQLConnect:TSQLConnect;
  876. var SQLDisconnect:TSQLDisconnect;
  877. var SQLDriverConnect:TSQLDriverConnect;
  878. var SQLExecDirect:TSQLExecDirect;
  879. var SQLPrepare:TSQLPrepare;
  880. var SQLCloseCursor:TSQLCloseCursor;
  881. var SQLExecute:TSQLExecute;
  882. var SQLFetch:TSQLFetch;
  883. var SQLNumResultCols:TSQLNumResultCols;
  884. var SQLDescribeCol:TSQLDescribeCol;
  885. var SQLFetchScroll:TSQLFetchScroll;
  886. var SQLExtendedFetch:TSQLExtendedFetch;
  887. var SQLGetData:TSQLGetData;
  888. var SQLSetStmtAttr:TSQLSetStmtAttr;
  889. var SQLGetStmtAttr:TSQLGetStmtAttr;
  890. var SQLBulkOperations:TSQLBulkOperations;
  891. var SQLPutData:TSQLPutData;
  892. var SQLBindCol:TSQLBindCol;
  893. var SQLSetPos:TSQLSetPos;
  894. var SQLDataSources:TSQLDataSources;
  895. var SQLDrivers:TSQLDrivers;
  896. var SQLSetConnectAttr:TSQLSetConnectAttr;
  897. var SQLGetCursorName:TSQLGetCursorName;
  898. var SQLSetCursorName:TSQLSetCursorName;
  899. var SQLRowCount:TSQLRowCount;
  900. var SQLBindParameter:TSQLBindParameter;
  901. var SQLFreeStmt:TSQLFreeStmt;
  902. var SQLColAttribute:TSQLColAttribute;
  903. var SQLEndTran:TSQLEndTran;
  904. var SQLTables:TSQLTables;
  905. var SQLPrimaryKeys:TSQLPrimaryKeys;
  906. var SQLProcedureColumns : TSQLProcedureColumns;
  907. var odbcversion:word;
  908. {$else}
  909. {$ifdef unix}
  910. Const
  911. LibName = 'odbc';
  912. {$else}
  913. LibName = 'odbc32.dll';
  914. {$endif}
  915. function SQLAllocHandle(
  916. HandleType: SQLSMALLINT;
  917. InputHandle:SQLHANDLE;
  918. Var OutputHandlePtr: SQLHANDLE):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  919. function SQLSetEnvAttr(
  920. EnvironmentHandle:SQLHENV;
  921. Attribute: SQLINTEGER;
  922. Value: SQLPOINTER;
  923. StringLength: SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  924. function SQLGetEnvAttr(
  925. EnvironmentHandle:SQLHENV;
  926. Attribute:SQLINTEGER;
  927. Value:SQLPOINTER;
  928. BufferLength:SQLINTEGER;
  929. StringLength:PSQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  930. function SQLFreeHandle(
  931. HandleType: SQLSMALLINT;
  932. Handle: SQLHANDLE):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  933. function SQLGetDiagRec(
  934. HandleType: SQLSMALLINT;
  935. Handle: SQLHANDLE;
  936. RecNumber: SQLSMALLINT;
  937. Sqlstate: PSQLCHAR;
  938. var NativeError: SQLINTEGER;
  939. MessageText: PSQLCHAR;
  940. BufferLength: SQLSMALLINT;
  941. var TextLength: SQLSMALLINT ):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  942. function SQLConnect(
  943. ConnectionHandle:SQLHDBC;
  944. ServerName:PSQLCHAR; NameLength1:SQLSMALLINT;
  945. UserName:PSQLCHAR; NameLength2:SQLSMALLINT;
  946. Authentication:PSQLCHAR;NameLength3:SQLSMALLINT
  947. ):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  948. function SQLDisconnect(
  949. ConnectionHandle:SQLHDBC):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  950. function SQLDriverConnect(
  951. hdbc: SQLHDBC;
  952. hwnd: Integer;
  953. szCsin: PChar;
  954. szCLen: SQLSMALLINT;
  955. szCsout: PChar;
  956. cbCSMax: SQLSMALLINT;
  957. Var cbCsOut: SQLSMALLINT;
  958. f: Integer):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  959. function SQLBrowseConnect(
  960. hdbc : SQLHDBC;
  961. szConnStrIn :PSQLCHAR;
  962. cbConnStrIn: SQLSMALLINT;
  963. szConnStrOut : PSQLCHAR;
  964. cbConnStrOutMax : SQLSMALLINT;
  965. Var cbConnStrOut : SQLSMALLINT) : SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  966. function SQLExecDirect(
  967. StatementHandle:SQLHSTMT;
  968. StatementText: PSQLCHAR;
  969. TextLength: SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  970. function SQLPrepare(
  971. StatementHandle:SQLHSTMT;
  972. StatementText:PSQLCHAR;
  973. TextLength:SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  974. function SQLCloseCursor(
  975. StatementHandle:SQLHSTMT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  976. function SQLExecute(
  977. StatementHandle:SQLHSTMT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  978. function SQLFetch(
  979. StatementHandle:SQLHSTMT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  980. function SQLNumResultCols(
  981. StatementHandle:SQLHSTMT;
  982. var ColumnCount:SQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  983. function SQLDescribeCol(
  984. StatementHandle:SQLHSTMT;
  985. ColumnNumber:SQLUSMALLINT;
  986. ColumnName:PSQLCHAR;
  987. BufferLength:SQLSMALLINT;
  988. var NameLength:SQLSMALLINT;
  989. var DataType:SQLSMALLINT;
  990. var ColumnSize:SQLUINTEGER;
  991. var DecimalDigits:SQLSMALLINT;
  992. var Nullable:SQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  993. function SQLFetchScroll(
  994. StatementHandle:SQLHSTMT;
  995. FetchOrientation:SQLSMALLINT;
  996. FetchOffset:SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  997. function SQLExtendedFetch(
  998. hstmt:SQLHSTMT;
  999. fFetchType:SQLUSMALLINT;
  1000. irow:SQLINTEGER;
  1001. pcrow:PSQLUINTEGER;
  1002. rgfRowStatus:PSQLUSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1003. function SQLGetData(
  1004. StatementHandle:SQLHSTMT;
  1005. ColumnNumber:SQLUSMALLINT;
  1006. TargetType:SQLSMALLINT;
  1007. TargetValue:SQLPOINTER;
  1008. BufferLength:SQLINTEGER;
  1009. StrLen_or_Ind:PSQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1010. function SQLSetStmtAttr(
  1011. StatementHandle:SQLHSTMT;
  1012. Attribute:SQLINTEGER;
  1013. Value:SQLPOINTER;
  1014. StringLength:SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1015. function SQLGetStmtAttr(
  1016. StatementHandle:SQLHSTMT;
  1017. Attribute:SQLINTEGER;
  1018. Value:SQLPOINTER;
  1019. BufferLength:SQLINTEGER;
  1020. StringLength:PSQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1021. function SQLGetInfo(
  1022. ConnectionHandle:SQLHDBC;
  1023. InfoType:SQLUSMALLINT;
  1024. InfoValue:SQLPOINTER;
  1025. BufferLength:SQLSMALLINT;
  1026. StringLength:PSQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1027. function SQLBulkOperations(
  1028. StatementHandle: SQLHSTMT;
  1029. Operation:SQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1030. function SQLPutData(
  1031. StatementHandle:SQLHSTMT;
  1032. Data:SQLPOINTER;
  1033. StrLen_or_Ind:SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1034. function SQLBindCol(
  1035. StatementHandle:SQLHSTMT;
  1036. ColumnNumber:SQLUSMALLINT;
  1037. TargetType:SQLSMALLINT;
  1038. TargetValue:SQLPOINTER;
  1039. BufferLength:SQLINTEGER;
  1040. StrLen_or_Ind:PSQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1041. function SQLSetPos(
  1042. hstmt:SQLHSTMT;
  1043. irow:SQLUSMALLINT;
  1044. fOption:SQLUSMALLINT;
  1045. fLock:SQLUSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1046. function SQLDataSources(
  1047. EnvironmentHandle:SQLHENV;
  1048. Direction:SQLUSMALLINT;
  1049. ServerName:PSQLCHAR;
  1050. BufferLength1:SQLSMALLINT;
  1051. NameLength1:PSQLSMALLINT;
  1052. Description:PSQLCHAR;
  1053. BufferLength2:SQLSMALLINT;
  1054. NameLength2:PSQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1055. function SQLDrivers(
  1056. EnvironmentHandle:SQLHENV;
  1057. Direction:SQLUSMALLINT;
  1058. DriverDescription:PSQLCHAR;
  1059. BufferLength1:SQLSMALLINT;
  1060. DescriptionLength1:PSQLSMALLINT;
  1061. DriverAttributes:PSQLCHAR;
  1062. BufferLength2:SQLSMALLINT;
  1063. AttributesLength2:PSQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1064. function SQLSetConnectAttr(
  1065. ConnectionHandle:SQLHDBC;
  1066. Attribute:SQLINTEGER; Value:SQLPOINTER;
  1067. StringLength:SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1068. function SQLGetCursorName(
  1069. StatementHandle:SQLHSTMT;
  1070. CursorName:PSQLCHAR; BufferLength:SQLSMALLINT;
  1071. NameLength:PSQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1072. function SQLSetCursorName(
  1073. StatementHandle:SQLHSTMT;
  1074. CursorName:PSQLCHAR; NameLength:SQLSMALLINT
  1075. ):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1076. function SQLRowCount(
  1077. StatementHandle:SQLHSTMT;
  1078. Var RowCount:SQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1079. function SQLBindParameter(
  1080. hstmt:SQLHSTMT;
  1081. ipar:SQLUSMALLINT;
  1082. fParamType:SQLSMALLINT;
  1083. fCType:SQLSMALLINT;
  1084. fSqlType:SQLSMALLINT;
  1085. cbColDef:SQLUINTEGER;
  1086. ibScale:SQLSMALLINT;
  1087. rgbValue:SQLPOINTER;
  1088. cbValueMax:SQLINTEGER;
  1089. pcbValue:PSQLINTEGER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1090. function SQLFreeStmt(
  1091. StatementHandle:SQLHSTMT;
  1092. Option:SQLUSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1093. function SQLColAttribute (
  1094. StatementHandle:SQLHSTMT;
  1095. ColumnNumber:SQLUSMALLINT;
  1096. FieldIdentifier:SQLUSMALLINT;
  1097. CharacterAttribute:PSQLCHAR;
  1098. BufferLength:SQLSMALLINT;
  1099. StringLength:PSQLSMALLINT;
  1100. NumericAttribute:SQLPOINTER):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1101. {$ifdef ODBCVER3}
  1102. function SQLEndTran(
  1103. HandleType:SQLSMALLINT;
  1104. Handle:SQLHANDLE;
  1105. CompletionType:SQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1106. {$endif}
  1107. function SQLTables( hstmt : SQLHSTMT;
  1108. szTableQualifier : PSQLCHAR;
  1109. cbTableQualifier : SQLSMALLINT;
  1110. szTableOwner : PSQLCHAR;
  1111. cbTableOwner : SQLSMALLINT;
  1112. szTableName : PSQLCHAR;
  1113. cbTableName : SQLSMALLINT;
  1114. szTableType : PSQLCHAR;
  1115. cbTableType : SQLSMALLINT ) : SQLRETURN; {$ifdef win32}stdcall{$else}cdecl{$endif}; external LibName;
  1116. function SQLColumns( hstmt : SQLHSTMT;
  1117. szTableQualifier : PSQLCHAR;
  1118. cbTableQualifier : SQLSMALLINT;
  1119. szTableOwner : PSQLCHAR;
  1120. cbTableOwner : SQLSMALLINT;
  1121. szTableName : PSQLCHAR;
  1122. cbTableName : SQLSMALLINT;
  1123. szColumnName : PSQLCHAR;
  1124. cbColumnName : SQLSMALLINT ) : SQLRETURN; {$ifdef win32}stdcall{$else}cdecl{$endif}; external LibName;
  1125. function SQLSpecialColumns(StatementHandle:SQLHSTMT;
  1126. IdentifierType:SQLUSMALLINT;
  1127. CatalogName:PSQLCHAR;
  1128. NameLength1:SQLSMALLINT;
  1129. SchemaName:PSQLCHAR;
  1130. NameLength2:SQLSMALLINT;
  1131. TableName:PSQLCHAR;
  1132. NameLength3:SQLSMALLINT;
  1133. Scope:SQLUSMALLINT;
  1134. Nullable:SQLUSMALLINT) : SQLRETURN; {$ifdef win32}stdcall{$else}cdecl{$endif}; external LibName;
  1135. function SQLProcedures( hstmt : SQLHSTMT;
  1136. szTableQualifier : PSQLCHAR;
  1137. cbTableQualifier : SQLSMALLINT;
  1138. szTableOwner : PSQLCHAR;
  1139. cbTableOwner : SQLSMALLINT;
  1140. szTableName : PSQLCHAR;
  1141. cbTableName : SQLSMALLINT ) : SQLRETURN; {$ifdef win32}stdcall{$else}cdecl{$endif}; external LibName;
  1142. function SQLPrimaryKeys(hstmt : SQLHSTMT;
  1143. CatalogName:PSQLCHAR;NameLength1:SQLSMALLINT;
  1144. SchemaName:PSQLCHAR;NameLength2:SQLSMALLINT;
  1145. TableName:PSQLCHAR;
  1146. NameLength3:SQLSMALLINT):SQLRETURN;{$ifdef win32}stdcall{$else}cdecl{$endif};external LibName;
  1147. function SQLProcedureColumns(hstmt: SQLHSTMT;
  1148. CatalogName: PSQLCHAR; NameLength1: SQLSMALLINT;
  1149. SchemaName: PSQLCHAR; NameLength2: SQLSMALLINT;
  1150. ProcName: PSQLCHAR; NameLength3: SQLSMALLINT;
  1151. ColumnName: PSQLCHAR; NameLength4: SQLSMALLINT): SQLRETURN; {$ifdef win32}stdcall{$else}cdecl{$endif};
  1152. external LibName;
  1153. {$endif}
  1154. // This function always load dynamic
  1155. type TSQLConfigDataSource=function (
  1156. hwndParent: Integer;
  1157. fRequest: Integer;
  1158. lpszDriverString: String;
  1159. lpszAttributes: String): SQLRETURN;stdcall;
  1160. TSQLInstallerError=function (
  1161. iError: SQLUSMALLINT;
  1162. pfErrorCode: PSQLINTEGER;
  1163. lpszErrorMsg: PCHAR;
  1164. cbErrorMsgMax: SQLUSMALLINT;
  1165. pcbErrorMsg: PSQLUSMALLINT): SQLRETURN;stdcall;
  1166. {$ifndef unix}
  1167. function SQLConfigDataSource(
  1168. hwndParent: Integer;
  1169. fRequest: Integer;
  1170. lpszDriverString: String;
  1171. lpszAttributes: String): Integer;stdcall;
  1172. function SQLInstallerError(
  1173. iError: SQLUSMALLINT;
  1174. pfErrorCode: PSQLINTEGER;
  1175. lpszErrorMsg: PCHAR;
  1176. cbErrorMsgMax: SQLUSMALLINT;
  1177. pcbErrorMsg: PSQLUSMALLINT): SQLRETURN;
  1178. {$endif}
  1179. function DateStructToDateTime( b:PSQL_DATE_STRUCT):TDateTime;
  1180. function DateTimeToDateStruct( b:TDateTime):SQL_DATE_STRUCT;
  1181. procedure DateTime2TimeStampStruct( var Value:SQL_TIMESTAMP_STRUCT; b:TDateTime);
  1182. Function TimeStampStructToDateTime( B : PSQL_TIMESTAMP_STRUCT) : TDateTime;
  1183. Function TimeStructToDateTime (B : PSQL_TIME_STRUCT) : TDateTime;
  1184. procedure LoadOdbc;
  1185. procedure UnLoadOdbc;
  1186. implementation
  1187. {$ifndef unix}
  1188. uses Windows;
  1189. {$endif}
  1190. {$IFDEF VER110}
  1191. {$HPPEMIT '#pragma comment(lib,"odbc32.lib")'}
  1192. {$ENDIF}
  1193. {$ifndef unix}
  1194. Var
  1195. {$IFDEF DYNLOADINGODBC}
  1196. OdbcHMODULE: HMODULE;
  1197. {$ENDIF}
  1198. OdbccpHMODULE:HMODULE;
  1199. {$endif}
  1200. function DateStructToDateTime( b:PSQL_DATE_STRUCT):TDateTime;
  1201. begin
  1202. Result:=EncodeDate( b^.Year, b^.Month, b^.Day);
  1203. end;
  1204. function DateTimeToDateStruct( b:TDateTime):SQL_DATE_STRUCT;
  1205. var
  1206. y,m,d: Word;
  1207. begin
  1208. DecodeDate( b, y, m, d);
  1209. with Result do
  1210. begin
  1211. Year:=y; Month:=m; Day:=d;
  1212. end;
  1213. end;
  1214. procedure DateTime2TimeStampStruct( var Value:SQL_TIMESTAMP_STRUCT; b:TDateTime);
  1215. var
  1216. w1,w2,w3,w4: Word;
  1217. begin
  1218. with Value do
  1219. begin
  1220. DecodeDate(b,w1,w2,w3);
  1221. Year := w1;
  1222. Month := w2;
  1223. Day := w3;
  1224. DecodeTime(b,w1,w2,w3,w4);
  1225. Hour := w1;
  1226. Minute := w2;
  1227. Second := w3;
  1228. fraction := Integer(w4)*1000000;
  1229. end;
  1230. end;
  1231. {
  1232. SQL_DATE_STRUCT = packed record
  1233. Year : SQLSMALLINT;
  1234. Month : SQLUSMALLINT;
  1235. Day : SQLUSMALLINT;
  1236. end;
  1237. PSQL_DATE_STRUCT = ^SQL_DATE_STRUCT;
  1238. }
  1239. Function TimeStampStructToDateTime( B : PSQL_TIMESTAMP_STRUCT) : TDateTime;
  1240. begin
  1241. With B^ do
  1242. Result:=EncodeDate(Year,Month,Day)+
  1243. EncodeTime(Hour,Minute,Second,0);
  1244. end;
  1245. Function TimeStructToDateTime (B : PSQL_TIME_STRUCT) : TDateTime;
  1246. begin
  1247. With B^ do
  1248. Result:=EncodeTime(Hour,Minute,Second,0);
  1249. end;
  1250. {$ifdef DYNLOADINGODBC}
  1251. Function GetODBCVersion(Odbc:HMODULE):word;
  1252. var
  1253. lpFilename:pchar;
  1254. {$IFDEF D4UP}
  1255. tmp,lpdwHandle:cardinal;
  1256. {$ELSE}
  1257. tmp,lpdwHandle:integer;
  1258. {$ENDIF}
  1259. F,lpData:pointer;
  1260. begin
  1261. getmem(lpFilename,255);
  1262. if GetModuleFileName(Odbc,lpFilename,254) = 0 then
  1263. raise Exception.Create('Error while get module file name');
  1264. lpdwHandle:=GetFileVersionInfoSize(lpFilename,tmp);
  1265. getmem( lpdata, lpdwHandle);
  1266. result := 0;
  1267. if GetFileVersionInfo(lpFilename,0,lpdwHandle,lpData) then
  1268. begin
  1269. {$IFDEF D4UP}
  1270. tmp := sizeof(tagVS_FIXEDFILEINFO);
  1271. {$ELSE}
  1272. tmp := sizeof(TVSFixedFileInfo);
  1273. {$ENDIF}
  1274. VerQueryValue( lpData, '\', f, tmp);
  1275. result := hiword(PVSFixedFileInfo(f).dwProductVersionMS) * 256 + Loword(PVSFixedFileInfo(f).dwProductVersionMS);
  1276. end;
  1277. Freemem(lpdata,lpdwHandle);
  1278. Freemem(lpFilename,255);
  1279. end;
  1280. Function GetAdresstoFunction(funcname:string):FARPROC;
  1281. begin
  1282. result:=GetProcAddress(OdbcHMODULE,pchar(funcname));
  1283. if result = nil then
  1284. begin
  1285. //result:=@ThisFunctionisnotavailable;
  1286. raise Exception.create('Error Getting adress for '+Funcname+#13+syserrormessage(GetLastError));
  1287. end;
  1288. end;
  1289. {$endif}
  1290. function syserrormessage(I : Integer) : string;
  1291. begin
  1292. result:='error '+inttostr(i);
  1293. end;
  1294. procedure LoadOdbc;
  1295. begin
  1296. {$ifdef DYNLOADINGODBC}
  1297. if OdbcHMODULE <> 0 then
  1298. exit;
  1299. OdbcHMODULE := LoadLibrary('ODBC32.DLL');
  1300. if OdbcHMODULE = 0 then
  1301. raise Exception.create(syserrormessage(GetLastError));
  1302. odbcversion:=GetODBCVersion(OdbcHMODULE);
  1303. //Here we know the version of the odbc driver. eg '3.5'
  1304. SQLAllocHandle:=GetAdresstoFunction('SQLAllocHandle');
  1305. SQLSetEnvAttr:=GetAdresstoFunction('SQLSetEnvAttr');
  1306. SQLFreeHandle:=GetAdresstoFunction('SQLFreeHandle');
  1307. SQLGetInfo:=GetAdresstoFunction('SQLGetInfo');
  1308. SQLProcedures:=GetAdresstoFunction('SQLProcedures');
  1309. SQLColumns:=GetAdresstoFunction('SQLColumns');
  1310. SQLSpecialColumns:=GetAdresstoFunction('SQLSpecialColumns');
  1311. SQLGetDiagRec:=GetAdresstoFunction('SQLGetDiagRec');
  1312. SQLConnect:=GetAdresstoFunction('SQLConnect');
  1313. SQLDisconnect:=GetAdresstoFunction('SQLDisconnect');
  1314. SQLDriverConnect:=GetAdresstoFunction('SQLDriverConnect');
  1315. SQLExecDirect:=GetAdresstoFunction('SQLExecDirect');
  1316. SQLPrepare:=GetAdresstoFunction('SQLPrepare');
  1317. SQLCloseCursor:=GetAdresstoFunction('SQLCloseCursor');
  1318. SQLExecute:=GetAdresstoFunction('SQLExecute');
  1319. SQLFetch:=GetAdresstoFunction('SQLFetch');
  1320. SQLNumResultCols:=GetAdresstoFunction('SQLNumResultCols');
  1321. SQLDescribeCol:=GetAdresstoFunction('SQLDescribeCol');
  1322. SQLFetchScroll:=GetAdresstoFunction('SQLFetchScroll');
  1323. SQLExtendedFetch:=GetAdresstoFunction('SQLExtendedFetch');
  1324. SQLGetData:=GetAdresstoFunction('SQLGetData');
  1325. SQLSetStmtAttr:=GetAdresstoFunction('SQLSetStmtAttr');
  1326. SQLGetStmtAttr:=GetAdresstoFunction('SQLGetStmtAttr');
  1327. SQLBulkOperations:=GetAdresstoFunction('SQLBulkOperations');
  1328. SQLPutData:=GetAdresstoFunction('SQLPutData');
  1329. SQLBindCol:=GetAdresstoFunction('SQLBindCol');
  1330. SQLSetPos:=GetAdresstoFunction('SQLSetPos');
  1331. SQLDataSources:=GetAdresstoFunction('SQLDataSources');
  1332. SQLDrivers:=GetAdresstoFunction('SQLDrivers');
  1333. SQLSetConnectAttr:=GetAdresstoFunction('SQLSetConnectAttr');
  1334. SQLGetCursorName:=GetAdresstoFunction('SQLGetCursorName');
  1335. SQLSetCursorName:=GetAdresstoFunction('SQLSetCursorName');
  1336. SQLRowCount:=GetAdresstoFunction('SQLRowCount');
  1337. SQLBindParameter:=GetAdresstoFunction('SQLBindParameter');
  1338. SQLFreeStmt:=GetAdresstoFunction('SQLFreeStmt');
  1339. SQLColAttribute:=GetAdresstoFunction('SQLColAttribute');
  1340. SQLEndTran:=GetAdresstoFunction('SQLEndTran');
  1341. SQLTables:=GetAdresstoFunction('SQLTables');
  1342. SQLPrimaryKeys:=GetAdresstoFunction('SQLPrimaryKeys');
  1343. SQLProcedureColumns:=GetAdresstoFunction('SQLProcedureColumns');
  1344. {$endif}
  1345. end;
  1346. procedure UnLoadOdbc;
  1347. begin
  1348. {$ifdef DYNLOADINGODBC}
  1349. if OdbcHMODULE<>0 then
  1350. begin
  1351. if not FreeLibrary(OdbcHMODULE) then
  1352. begin
  1353. raise Exception.create(syserrormessage(GetLastError));
  1354. end;
  1355. end;
  1356. OdbcHMODULE := 0;
  1357. {$endif}
  1358. {$ifndef unix}
  1359. if OdbccpHMODULE <> 0 then
  1360. begin
  1361. if not FreeLibrary(OdbccpHMODULE) then
  1362. begin
  1363. raise Exception.create(syserrormessage(GetLastError));
  1364. end;
  1365. end;
  1366. OdbccpHMODULE:=0;
  1367. {$endif}
  1368. end;
  1369. // function SQLConfigDataSource(
  1370. // hwndParent: Integer;
  1371. // fRequest: Integer;
  1372. // lpszDriverString: String;
  1373. // lpszAttributes: String): Integer;stdcall;external 'ODBCCP32.DLL';
  1374. {$ifndef unix}
  1375. function SQLConfigDataSource(
  1376. hwndParent: Integer;
  1377. fRequest: Integer;
  1378. lpszDriverString: String;
  1379. lpszAttributes: String): Integer;stdcall;
  1380. var
  1381. func: TSQLConfigDataSource;
  1382. begin
  1383. if OdbccpHMODULE = 0 then
  1384. begin
  1385. OdbccpHMODULE := LoadLibrary('ODBCCP32.DLL');
  1386. if OdbccpHMODULE = 0 then
  1387. raise Exception.create(syserrormessage(GetLastError));
  1388. end;
  1389. func := TSQLConfigDataSource(GetProcAddress(OdbccpHMODULE,pchar('SQLConfigDataSource')));
  1390. if @func = nil then
  1391. raise Exception.create('Error Getting adress for SQLConfigDataSource'+#13+syserrormessage(GetLastError));
  1392. Result := func(hwndParent,fRequest,lpszDriverString,lpszAttributes);
  1393. end;
  1394. //SQLRETURN INSTAPI SQLInstallerError(WORD iError,
  1395. // DWORD *pfErrorCode,
  1396. // LPSTR lpszErrorMsg,
  1397. // WORD cbErrorMsgMax,
  1398. // WORD *pcbErrorMsg);
  1399. function SQLInstallerError(
  1400. iError: SQLUSMALLINT;
  1401. pfErrorCode: PSQLINTEGER;
  1402. lpszErrorMsg: PCHAR;
  1403. cbErrorMsgMax: SQLUSMALLINT;
  1404. pcbErrorMsg: PSQLUSMALLINT): SQLRETURN;
  1405. var
  1406. func: TSQLInstallerError;
  1407. begin
  1408. if OdbccpHMODULE = 0 then
  1409. begin
  1410. OdbccpHMODULE := LoadLibrary('ODBCCP32.DLL');
  1411. if OdbccpHMODULE = 0 then
  1412. raise Exception.create(syserrormessage(GetLastError));
  1413. end;
  1414. func := TSQLInstallerError(GetProcAddress(OdbccpHMODULE,pchar('SQLInstallerError')));
  1415. if @func = nil then
  1416. raise Exception.create('Error Getting adress for SQLInstallerError'+#13+syserrormessage(GetLastError));
  1417. Result := func( iError, pfErrorCode, lpszErrorMsg, cbErrorMsgMax, pcbErrorMsg);
  1418. end;
  1419. {$endif}
  1420. initialization
  1421. finalization
  1422. begin
  1423. UnloadODBC;
  1424. end;
  1425. end.