odbcsql.inc 65 KB

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