odbcsql.nim 34 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848
  1. #
  2. #
  3. # Nim's Runtime Library
  4. # (c) Copyright 2015 Andreas Rumpf
  5. #
  6. # See the file "copying.txt", included in this
  7. # distribution, for details about the copyright.
  8. #
  9. {.deadCodeElim: on.} # dce option deprecated
  10. when not defined(ODBCVER):
  11. const
  12. ODBCVER = 0x0351 ## define ODBC version 3.51 by default
  13. when defined(windows):
  14. {.push callconv: stdcall.}
  15. const odbclib = "odbc32.dll"
  16. else:
  17. {.push callconv: cdecl.}
  18. const odbclib = "libodbc.so"
  19. # DATA TYPES CORRESPONDENCE
  20. # BDE fields ODBC types
  21. # ---------- ------------------
  22. # ftBlob SQL_BINARY
  23. # ftBoolean SQL_BIT
  24. # ftDate SQL_TYPE_DATE
  25. # ftTime SQL_TYPE_TIME
  26. # ftDateTime SQL_TYPE_TIMESTAMP
  27. # ftInteger SQL_INTEGER
  28. # ftSmallint SQL_SMALLINT
  29. # ftFloat SQL_DOUBLE
  30. # ftString SQL_CHAR
  31. # ftMemo SQL_BINARY // SQL_VARCHAR
  32. #
  33. type
  34. TSqlChar* = char
  35. TSqlSmallInt* = int16
  36. SqlUSmallInt* = int16
  37. SqlHandle* = pointer
  38. SqlHEnv* = SqlHandle
  39. SqlHDBC* = SqlHandle
  40. SqlHStmt* = SqlHandle
  41. SqlHDesc* = SqlHandle
  42. TSqlInteger* = int
  43. SqlUInteger* = int
  44. SqlPointer* = pointer
  45. TSqlReal* = cfloat
  46. TSqlDouble* = cdouble
  47. TSqlFloat* = cdouble
  48. SqlHWND* = pointer
  49. PSQLCHAR* = cstring
  50. PSQLINTEGER* = ptr TSqlInteger
  51. PSQLUINTEGER* = ptr SqlUInteger
  52. PSQLSMALLINT* = ptr TSqlSmallInt
  53. PSQLUSMALLINT* = ptr SqlUSmallInt
  54. PSQLREAL* = ptr TSqlReal
  55. PSQLDOUBLE* = ptr TSqlDouble
  56. PSQLFLOAT* = ptr TSqlFloat
  57. PSQLHANDLE* = ptr SqlHandle
  58. {.deprecated: [
  59. # TSqlChar: TSqlChar, # Name conflict if we drop`T`
  60. # TSqlSmallInt: TSqlSmallInt, # Name conflict if we drop`T`
  61. TSqlUSmallInt: SqlUSmallInt, TSqlHandle: SqlHandle, TSqlHEnv: SqlHEnv,
  62. TSqlHDBC: SqlHDBC, TSqlHStmt: SqlHStmt, TSqlHDesc: SqlHDesc,
  63. # TSqlInteger: TSqlInteger, # Name conflict if we drop `T`
  64. TSqlUInteger: SqlUInteger, TSqlPointer: SqlPointer,
  65. # TSqlReal: TSqlReal, # Name conflict if we drop`T`
  66. # TSqlDouble: TSqlDouble, # Name conflict if we drop`T`
  67. # TSqlFloat: TSqlFloat, # Name conflict if we drop `T`
  68. TSqlHWND: SqlHWND].}
  69. const # SQL data type codes
  70. SQL_UNKNOWN_TYPE* = 0
  71. SQL_LONGVARCHAR* = (- 1)
  72. SQL_BINARY* = (- 2)
  73. SQL_VARBINARY* = (- 3)
  74. SQL_LONGVARBINARY* = (- 4)
  75. SQL_BIGINT* = (- 5)
  76. SQL_TINYINT* = (- 6)
  77. SQL_BIT* = (- 7)
  78. SQL_WCHAR* = (- 8)
  79. SQL_WVARCHAR* = (- 9)
  80. SQL_WLONGVARCHAR* = (- 10)
  81. SQL_CHAR* = 1
  82. SQL_NUMERIC* = 2
  83. SQL_DECIMAL* = 3
  84. SQL_INTEGER* = 4
  85. SQL_SMALLINT* = 5
  86. SQL_FLOAT* = 6
  87. SQL_REAL* = 7
  88. SQL_DOUBLE* = 8
  89. SQL_DATETIME* = 9
  90. SQL_VARCHAR* = 12
  91. SQL_TYPE_DATE* = 91
  92. SQL_TYPE_TIME* = 92
  93. SQL_TYPE_TIMESTAMP* = 93
  94. SQL_DATE* = 9
  95. SQL_TIME* = 10
  96. SQL_TIMESTAMP* = 11
  97. SQL_INTERVAL* = 10
  98. SQL_GUID* = - 11 # interval codes
  99. when ODBCVER >= 0x0300:
  100. const
  101. SQL_CODE_YEAR* = 1
  102. SQL_CODE_MONTH* = 2
  103. SQL_CODE_DAY* = 3
  104. SQL_CODE_HOUR* = 4
  105. SQL_CODE_MINUTE* = 5
  106. SQL_CODE_SECOND* = 6
  107. SQL_CODE_YEAR_TO_MONTH* = 7
  108. SQL_CODE_DAY_TO_HOUR* = 8
  109. SQL_CODE_DAY_TO_MINUTE* = 9
  110. SQL_CODE_DAY_TO_SECOND* = 10
  111. SQL_CODE_HOUR_TO_MINUTE* = 11
  112. SQL_CODE_HOUR_TO_SECOND* = 12
  113. SQL_CODE_MINUTE_TO_SECOND* = 13
  114. SQL_INTERVAL_YEAR* = 100 + SQL_CODE_YEAR
  115. SQL_INTERVAL_MONTH* = 100 + SQL_CODE_MONTH
  116. SQL_INTERVAL_DAY* = 100 + SQL_CODE_DAY
  117. SQL_INTERVAL_HOUR* = 100 + SQL_CODE_HOUR
  118. SQL_INTERVAL_MINUTE* = 100 + SQL_CODE_MINUTE
  119. SQL_INTERVAL_SECOND* = 100 + SQL_CODE_SECOND
  120. SQL_INTERVAL_YEAR_TO_MONTH* = 100 + SQL_CODE_YEAR_TO_MONTH
  121. SQL_INTERVAL_DAY_TO_HOUR* = 100 + SQL_CODE_DAY_TO_HOUR
  122. SQL_INTERVAL_DAY_TO_MINUTE* = 100 + SQL_CODE_DAY_TO_MINUTE
  123. SQL_INTERVAL_DAY_TO_SECOND* = 100 + SQL_CODE_DAY_TO_SECOND
  124. SQL_INTERVAL_HOUR_TO_MINUTE* = 100 + SQL_CODE_HOUR_TO_MINUTE
  125. SQL_INTERVAL_HOUR_TO_SECOND* = 100 + SQL_CODE_HOUR_TO_SECOND
  126. SQL_INTERVAL_MINUTE_TO_SECOND* = 100 + SQL_CODE_MINUTE_TO_SECOND
  127. else:
  128. const
  129. SQL_INTERVAL_YEAR* = - 80
  130. SQL_INTERVAL_MONTH* = - 81
  131. SQL_INTERVAL_YEAR_TO_MONTH* = - 82
  132. SQL_INTERVAL_DAY* = - 83
  133. SQL_INTERVAL_HOUR* = - 84
  134. SQL_INTERVAL_MINUTE* = - 85
  135. SQL_INTERVAL_SECOND* = - 86
  136. SQL_INTERVAL_DAY_TO_HOUR* = - 87
  137. SQL_INTERVAL_DAY_TO_MINUTE* = - 88
  138. SQL_INTERVAL_DAY_TO_SECOND* = - 89
  139. SQL_INTERVAL_HOUR_TO_MINUTE* = - 90
  140. SQL_INTERVAL_HOUR_TO_SECOND* = - 91
  141. SQL_INTERVAL_MINUTE_TO_SECOND* = - 92
  142. when ODBCVER < 0x0300:
  143. const
  144. SQL_UNICODE* = - 95
  145. SQL_UNICODE_VARCHAR* = - 96
  146. SQL_UNICODE_LONGVARCHAR* = - 97
  147. SQL_UNICODE_CHAR* = SQL_UNICODE
  148. else:
  149. # The previous definitions for SQL_UNICODE_ are historical and obsolete
  150. const
  151. SQL_UNICODE* = SQL_WCHAR
  152. SQL_UNICODE_VARCHAR* = SQL_WVARCHAR
  153. SQL_UNICODE_LONGVARCHAR* = SQL_WLONGVARCHAR
  154. SQL_UNICODE_CHAR* = SQL_WCHAR
  155. const # C datatype to SQL datatype mapping
  156. SQL_C_CHAR* = SQL_CHAR
  157. SQL_C_LONG* = SQL_INTEGER
  158. SQL_C_SHORT* = SQL_SMALLINT
  159. SQL_C_FLOAT* = SQL_REAL
  160. SQL_C_DOUBLE* = SQL_DOUBLE
  161. SQL_C_NUMERIC* = SQL_NUMERIC
  162. SQL_C_DEFAULT* = 99
  163. SQL_SIGNED_OFFSET* = - 20
  164. SQL_UNSIGNED_OFFSET* = - 22
  165. SQL_C_DATE* = SQL_DATE
  166. SQL_C_TIME* = SQL_TIME
  167. SQL_C_TIMESTAMP* = SQL_TIMESTAMP
  168. SQL_C_TYPE_DATE* = SQL_TYPE_DATE
  169. SQL_C_TYPE_TIME* = SQL_TYPE_TIME
  170. SQL_C_TYPE_TIMESTAMP* = SQL_TYPE_TIMESTAMP
  171. SQL_C_INTERVAL_YEAR* = SQL_INTERVAL_YEAR
  172. SQL_C_INTERVAL_MONTH* = SQL_INTERVAL_MONTH
  173. SQL_C_INTERVAL_DAY* = SQL_INTERVAL_DAY
  174. SQL_C_INTERVAL_HOUR* = SQL_INTERVAL_HOUR
  175. SQL_C_INTERVAL_MINUTE* = SQL_INTERVAL_MINUTE
  176. SQL_C_INTERVAL_SECOND* = SQL_INTERVAL_SECOND
  177. SQL_C_INTERVAL_YEAR_TO_MONTH* = SQL_INTERVAL_YEAR_TO_MONTH
  178. SQL_C_INTERVAL_DAY_TO_HOUR* = SQL_INTERVAL_DAY_TO_HOUR
  179. SQL_C_INTERVAL_DAY_TO_MINUTE* = SQL_INTERVAL_DAY_TO_MINUTE
  180. SQL_C_INTERVAL_DAY_TO_SECOND* = SQL_INTERVAL_DAY_TO_SECOND
  181. SQL_C_INTERVAL_HOUR_TO_MINUTE* = SQL_INTERVAL_HOUR_TO_MINUTE
  182. SQL_C_INTERVAL_HOUR_TO_SECOND* = SQL_INTERVAL_HOUR_TO_SECOND
  183. SQL_C_INTERVAL_MINUTE_TO_SECOND* = SQL_INTERVAL_MINUTE_TO_SECOND
  184. SQL_C_BINARY* = SQL_BINARY
  185. SQL_C_BIT* = SQL_BIT
  186. SQL_C_SBIGINT* = SQL_BIGINT + SQL_SIGNED_OFFSET # SIGNED BIGINT
  187. SQL_C_UBIGINT* = SQL_BIGINT + SQL_UNSIGNED_OFFSET # UNSIGNED BIGINT
  188. SQL_C_TINYINT* = SQL_TINYINT
  189. SQL_C_SLONG* = SQL_C_LONG + SQL_SIGNED_OFFSET # SIGNED INTEGER
  190. SQL_C_SSHORT* = SQL_C_SHORT + SQL_SIGNED_OFFSET # SIGNED SMALLINT
  191. SQL_C_STINYINT* = SQL_TINYINT + SQL_SIGNED_OFFSET # SIGNED TINYINT
  192. SQL_C_ULONG* = SQL_C_LONG + SQL_UNSIGNED_OFFSET # UNSIGNED INTEGER
  193. SQL_C_USHORT* = SQL_C_SHORT + SQL_UNSIGNED_OFFSET # UNSIGNED SMALLINT
  194. SQL_C_UTINYINT* = SQL_TINYINT + SQL_UNSIGNED_OFFSET # UNSIGNED TINYINT
  195. SQL_C_BOOKMARK* = SQL_C_ULONG # BOOKMARK
  196. SQL_C_GUID* = SQL_GUID
  197. SQL_TYPE_NULL* = 0
  198. when ODBCVER < 0x0300:
  199. const
  200. SQL_TYPE_MIN* = SQL_BIT
  201. SQL_TYPE_MAX* = SQL_VARCHAR
  202. const
  203. SQL_C_VARBOOKMARK* = SQL_C_BINARY
  204. SQL_API_SQLDESCRIBEPARAM* = 58
  205. SQL_NO_TOTAL* = - 4
  206. type
  207. SQL_DATE_STRUCT* {.final, pure.} = object
  208. Year*: TSqlSmallInt
  209. Month*: SqlUSmallInt
  210. Day*: SqlUSmallInt
  211. PSQL_DATE_STRUCT* = ptr SQL_DATE_STRUCT
  212. SQL_TIME_STRUCT* {.final, pure.} = object
  213. Hour*: SqlUSmallInt
  214. Minute*: SqlUSmallInt
  215. Second*: SqlUSmallInt
  216. PSQL_TIME_STRUCT* = ptr SQL_TIME_STRUCT
  217. SQL_TIMESTAMP_STRUCT* {.final, pure.} = object
  218. Year*: SqlUSmallInt
  219. Month*: SqlUSmallInt
  220. Day*: SqlUSmallInt
  221. Hour*: SqlUSmallInt
  222. Minute*: SqlUSmallInt
  223. Second*: SqlUSmallInt
  224. Fraction*: SqlUInteger
  225. PSQL_TIMESTAMP_STRUCT* = ptr SQL_TIMESTAMP_STRUCT
  226. const
  227. SQL_NAME_LEN* = 128
  228. SQL_OV_ODBC3* = 3
  229. SQL_OV_ODBC2* = 2
  230. SQL_ATTR_ODBC_VERSION* = 200 # Options for SQLDriverConnect
  231. SQL_DRIVER_NOPROMPT* = 0
  232. SQL_DRIVER_COMPLETE* = 1
  233. SQL_DRIVER_PROMPT* = 2
  234. SQL_DRIVER_COMPLETE_REQUIRED* = 3
  235. SQL_IS_POINTER* = (- 4) # whether an attribute is a pointer or not
  236. SQL_IS_UINTEGER* = (- 5)
  237. SQL_IS_INTEGER* = (- 6)
  238. SQL_IS_USMALLINT* = (- 7)
  239. SQL_IS_SMALLINT* = (- 8) # SQLExtendedFetch "fFetchType" values
  240. SQL_FETCH_BOOKMARK* = 8
  241. SQL_SCROLL_OPTIONS* = 44 # SQL_USE_BOOKMARKS options
  242. SQL_UB_OFF* = 0
  243. SQL_UB_ON* = 1
  244. SQL_UB_DEFAULT* = SQL_UB_OFF
  245. SQL_UB_FIXED* = SQL_UB_ON
  246. SQL_UB_VARIABLE* = 2 # SQL_SCROLL_OPTIONS masks
  247. SQL_SO_FORWARD_ONLY* = 0x00000001
  248. SQL_SO_KEYSET_DRIVEN* = 0x00000002
  249. SQL_SO_DYNAMIC* = 0x00000004
  250. SQL_SO_MIXED* = 0x00000008
  251. SQL_SO_STATIC* = 0x00000010
  252. SQL_BOOKMARK_PERSISTENCE* = 82
  253. SQL_STATIC_SENSITIVITY* = 83 # SQL_BOOKMARK_PERSISTENCE values
  254. SQL_BP_CLOSE* = 0x00000001
  255. SQL_BP_DELETE* = 0x00000002
  256. SQL_BP_DROP* = 0x00000004
  257. SQL_BP_TRANSACTION* = 0x00000008
  258. SQL_BP_UPDATE* = 0x00000010
  259. SQL_BP_OTHER_HSTMT* = 0x00000020
  260. SQL_BP_SCROLL* = 0x00000040
  261. SQL_DYNAMIC_CURSOR_ATTRIBUTES1* = 144
  262. SQL_DYNAMIC_CURSOR_ATTRIBUTES2* = 145
  263. SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES1* = 146
  264. SQL_FORWARD_ONLY_CURSOR_ATTRIBUTES2* = 147
  265. SQL_INDEX_KEYWORDS* = 148
  266. SQL_INFO_SCHEMA_VIEWS* = 149
  267. SQL_KEYSET_CURSOR_ATTRIBUTES1* = 150
  268. SQL_KEYSET_CURSOR_ATTRIBUTES2* = 151
  269. SQL_STATIC_CURSOR_ATTRIBUTES1* = 167
  270. SQL_STATIC_CURSOR_ATTRIBUTES2* = 168 # supported SQLFetchScroll FetchOrientation's
  271. SQL_CA1_NEXT* = 1
  272. SQL_CA1_ABSOLUTE* = 2
  273. SQL_CA1_RELATIVE* = 4
  274. SQL_CA1_BOOKMARK* = 8 # supported SQLSetPos LockType's
  275. SQL_CA1_LOCK_NO_CHANGE* = 0x00000040
  276. SQL_CA1_LOCK_EXCLUSIVE* = 0x00000080
  277. SQL_CA1_LOCK_UNLOCK* = 0x00000100 # supported SQLSetPos Operations
  278. SQL_CA1_POS_POSITION* = 0x00000200
  279. SQL_CA1_POS_UPDATE* = 0x00000400
  280. SQL_CA1_POS_DELETE* = 0x00000800
  281. SQL_CA1_POS_REFRESH* = 0x00001000 # positioned updates and deletes
  282. SQL_CA1_POSITIONED_UPDATE* = 0x00002000
  283. SQL_CA1_POSITIONED_DELETE* = 0x00004000
  284. SQL_CA1_SELECT_FOR_UPDATE* = 0x00008000 # supported SQLBulkOperations operations
  285. SQL_CA1_BULK_ADD* = 0x00010000
  286. SQL_CA1_BULK_UPDATE_BY_BOOKMARK* = 0x00020000
  287. SQL_CA1_BULK_DELETE_BY_BOOKMARK* = 0x00040000
  288. SQL_CA1_BULK_FETCH_BY_BOOKMARK* = 0x00080000 # supported values for SQL_ATTR_SCROLL_CONCURRENCY
  289. SQL_CA2_READ_ONLY_CONCURRENCY* = 1
  290. SQL_CA2_LOCK_CONCURRENCY* = 2
  291. SQL_CA2_OPT_ROWVER_CONCURRENCY* = 4
  292. SQL_CA2_OPT_VALUES_CONCURRENCY* = 8 # sensitivity of the cursor to its own inserts, deletes, and updates
  293. SQL_CA2_SENSITIVITY_ADDITIONS* = 0x00000010
  294. SQL_CA2_SENSITIVITY_DELETIONS* = 0x00000020
  295. SQL_CA2_SENSITIVITY_UPDATES* = 0x00000040 # semantics of SQL_ATTR_MAX_ROWS
  296. SQL_CA2_MAX_ROWS_SELECT* = 0x00000080
  297. SQL_CA2_MAX_ROWS_INSERT* = 0x00000100
  298. SQL_CA2_MAX_ROWS_DELETE* = 0x00000200
  299. SQL_CA2_MAX_ROWS_UPDATE* = 0x00000400
  300. SQL_CA2_MAX_ROWS_CATALOG* = 0x00000800
  301. SQL_CA2_MAX_ROWS_AFFECTS_ALL* = (SQL_CA2_MAX_ROWS_SELECT or
  302. SQL_CA2_MAX_ROWS_INSERT or SQL_CA2_MAX_ROWS_DELETE or
  303. SQL_CA2_MAX_ROWS_UPDATE or SQL_CA2_MAX_ROWS_CATALOG) # semantics of
  304. # SQL_DIAG_CURSOR_ROW_COUNT
  305. SQL_CA2_CRC_EXACT* = 0x00001000
  306. SQL_CA2_CRC_APPROXIMATE* = 0x00002000 # the kinds of positioned statements that can be simulated
  307. SQL_CA2_SIMULATE_NON_UNIQUE* = 0x00004000
  308. SQL_CA2_SIMULATE_TRY_UNIQUE* = 0x00008000
  309. SQL_CA2_SIMULATE_UNIQUE* = 0x00010000 # Operations in SQLBulkOperations
  310. SQL_ADD* = 4
  311. SQL_SETPOS_MAX_OPTION_VALUE* = SQL_ADD
  312. SQL_UPDATE_BY_BOOKMARK* = 5
  313. SQL_DELETE_BY_BOOKMARK* = 6
  314. SQL_FETCH_BY_BOOKMARK* = 7 # Operations in SQLSetPos
  315. SQL_POSITION* = 0
  316. SQL_REFRESH* = 1
  317. SQL_UPDATE* = 2
  318. SQL_DELETE* = 3 # Lock options in SQLSetPos
  319. SQL_LOCK_NO_CHANGE* = 0
  320. SQL_LOCK_EXCLUSIVE* = 1
  321. SQL_LOCK_UNLOCK* = 2 # SQLExtendedFetch "rgfRowStatus" element values
  322. SQL_ROW_SUCCESS* = 0
  323. SQL_ROW_DELETED* = 1
  324. SQL_ROW_UPDATED* = 2
  325. SQL_ROW_NOROW* = 3
  326. SQL_ROW_ADDED* = 4
  327. SQL_ROW_ERROR* = 5
  328. SQL_ROW_SUCCESS_WITH_INFO* = 6
  329. SQL_ROW_PROCEED* = 0
  330. SQL_ROW_IGNORE* = 1
  331. SQL_MAX_DSN_LENGTH* = 32 # maximum data source name size
  332. SQL_MAX_OPTION_STRING_LENGTH* = 256
  333. SQL_ODBC_CURSORS* = 110
  334. SQL_ATTR_ODBC_CURSORS* = SQL_ODBC_CURSORS # SQL_ODBC_CURSORS options
  335. SQL_CUR_USE_IF_NEEDED* = 0
  336. SQL_CUR_USE_ODBC* = 1
  337. SQL_CUR_USE_DRIVER* = 2
  338. SQL_CUR_DEFAULT* = SQL_CUR_USE_DRIVER
  339. SQL_PARAM_TYPE_UNKNOWN* = 0
  340. SQL_PARAM_INPUT* = 1
  341. SQL_PARAM_INPUT_OUTPUT* = 2
  342. SQL_RESULT_COL* = 3
  343. SQL_PARAM_OUTPUT* = 4
  344. SQL_RETURN_VALUE* = 5 # special length/indicator values
  345. SQL_NULL_DATA* = (- 1)
  346. SQL_DATA_AT_EXEC* = (- 2)
  347. SQL_SUCCESS* = 0
  348. SQL_SUCCESS_WITH_INFO* = 1
  349. SQL_NO_DATA* = 100
  350. SQL_ERROR* = (- 1)
  351. SQL_INVALID_HANDLE* = (- 2)
  352. SQL_STILL_EXECUTING* = 2
  353. SQL_NEED_DATA* = 99 # flags for null-terminated string
  354. SQL_NTS* = (- 3) # maximum message length
  355. SQL_MAX_MESSAGE_LENGTH* = 512 # date/time length constants
  356. SQL_DATE_LEN* = 10
  357. SQL_TIME_LEN* = 8 # add P+1 if precision is nonzero
  358. SQL_TIMESTAMP_LEN* = 19 # add P+1 if precision is nonzero
  359. # handle type identifiers
  360. SQL_HANDLE_ENV* = 1
  361. SQL_HANDLE_DBC* = 2
  362. SQL_HANDLE_STMT* = 3
  363. SQL_HANDLE_DESC* = 4 # environment attribute
  364. SQL_ATTR_OUTPUT_NTS* = 10001 # connection attributes
  365. SQL_ATTR_AUTO_IPD* = 10001
  366. SQL_ATTR_METADATA_ID* = 10014 # statement attributes
  367. SQL_ATTR_APP_ROW_DESC* = 10010
  368. SQL_ATTR_APP_PARAM_DESC* = 10011
  369. SQL_ATTR_IMP_ROW_DESC* = 10012
  370. SQL_ATTR_IMP_PARAM_DESC* = 10013
  371. SQL_ATTR_CURSOR_SCROLLABLE* = (- 1)
  372. SQL_ATTR_CURSOR_SENSITIVITY* = (- 2)
  373. SQL_QUERY_TIMEOUT* = 0
  374. SQL_MAX_ROWS* = 1
  375. SQL_NOSCAN* = 2
  376. SQL_MAX_LENGTH* = 3
  377. SQL_ASYNC_ENABLE* = 4 # same as SQL_ATTR_ASYNC_ENABLE */
  378. SQL_BIND_TYPE* = 5
  379. SQL_CURSOR_TYPE* = 6
  380. SQL_CONCURRENCY* = 7
  381. SQL_KEYSET_SIZE* = 8
  382. SQL_ROWSET_SIZE* = 9
  383. SQL_SIMULATE_CURSOR* = 10
  384. SQL_RETRIEVE_DATA* = 11
  385. SQL_USE_BOOKMARKS* = 12
  386. SQL_GET_BOOKMARK* = 13 # GetStmtOption Only */
  387. SQL_ROW_NUMBER* = 14 # GetStmtOption Only */
  388. SQL_ATTR_CURSOR_TYPE* = SQL_CURSOR_TYPE
  389. SQL_ATTR_CONCURRENCY* = SQL_CONCURRENCY
  390. SQL_ATTR_FETCH_BOOKMARK_PTR* = 16
  391. SQL_ATTR_ROW_STATUS_PTR* = 25
  392. SQL_ATTR_ROWS_FETCHED_PTR* = 26
  393. SQL_AUTOCOMMIT* = 102
  394. SQL_ATTR_AUTOCOMMIT* = SQL_AUTOCOMMIT
  395. SQL_ATTR_ROW_NUMBER* = SQL_ROW_NUMBER
  396. SQL_TXN_ISOLATION* = 108
  397. SQL_ATTR_TXN_ISOLATION* = SQL_TXN_ISOLATION
  398. SQL_ATTR_MAX_ROWS* = SQL_MAX_ROWS
  399. SQL_ATTR_USE_BOOKMARKS* = SQL_USE_BOOKMARKS #* connection attributes */
  400. SQL_ACCESS_MODE* = 101 # SQL_AUTOCOMMIT =102;
  401. SQL_LOGIN_TIMEOUT* = 103
  402. SQL_OPT_TRACE* = 104
  403. SQL_OPT_TRACEFILE* = 105
  404. SQL_TRANSLATE_DLL* = 106
  405. SQL_TRANSLATE_OPTION* = 107 # SQL_TXN_ISOLATION =108;
  406. SQL_CURRENT_QUALIFIER* = 109 # SQL_ODBC_CURSORS =110;
  407. SQL_QUIET_MODE* = 111
  408. SQL_PACKET_SIZE* = 112 #* connection attributes with new names */
  409. SQL_ATTR_ACCESS_MODE* = SQL_ACCESS_MODE # SQL_ATTR_AUTOCOMMIT =SQL_AUTOCOMMIT;
  410. SQL_ATTR_CONNECTION_DEAD* = 1209 #* GetConnectAttr only */
  411. SQL_ATTR_CONNECTION_TIMEOUT* = 113
  412. SQL_ATTR_CURRENT_CATALOG* = SQL_CURRENT_QUALIFIER
  413. SQL_ATTR_DISCONNECT_BEHAVIOR* = 114
  414. SQL_ATTR_ENLIST_IN_DTC* = 1207
  415. SQL_ATTR_ENLIST_IN_XA* = 1208
  416. SQL_ATTR_LOGIN_TIMEOUT* = SQL_LOGIN_TIMEOUT # SQL_ATTR_ODBC_CURSORS =SQL_ODBC_CURSORS;
  417. SQL_ATTR_PACKET_SIZE* = SQL_PACKET_SIZE
  418. SQL_ATTR_QUIET_MODE* = SQL_QUIET_MODE
  419. SQL_ATTR_TRACE* = SQL_OPT_TRACE
  420. SQL_ATTR_TRACEFILE* = SQL_OPT_TRACEFILE
  421. SQL_ATTR_TRANSLATE_LIB* = SQL_TRANSLATE_DLL
  422. SQL_ATTR_TRANSLATE_OPTION* = SQL_TRANSLATE_OPTION # SQL_ATTR_TXN_ISOLATION =SQL_TXN_ISOLATION;
  423. #* SQL_ACCESS_MODE options */
  424. SQL_MODE_READ_WRITE* = 0
  425. SQL_MODE_READ_ONLY* = 1
  426. SQL_MODE_DEFAULT* = SQL_MODE_READ_WRITE #* SQL_AUTOCOMMIT options */
  427. SQL_AUTOCOMMIT_OFF* = 0
  428. SQL_AUTOCOMMIT_ON* = 1
  429. SQL_AUTOCOMMIT_DEFAULT* = SQL_AUTOCOMMIT_ON # SQL_ATTR_CURSOR_SCROLLABLE values
  430. SQL_NONSCROLLABLE* = 0
  431. SQL_SCROLLABLE* = 1 # SQL_CURSOR_TYPE options
  432. SQL_CURSOR_FORWARD_ONLY* = 0
  433. SQL_CURSOR_KEYSET_DRIVEN* = 1
  434. SQL_CURSOR_DYNAMIC* = 2
  435. SQL_CURSOR_STATIC* = 3
  436. SQL_CURSOR_TYPE_DEFAULT* = SQL_CURSOR_FORWARD_ONLY # Default value
  437. # SQL_CONCURRENCY options
  438. SQL_CONCUR_READ_ONLY* = 1
  439. SQL_CONCUR_LOCK* = 2
  440. SQL_CONCUR_ROWVER* = 3
  441. SQL_CONCUR_VALUES* = 4
  442. SQL_CONCUR_DEFAULT* = SQL_CONCUR_READ_ONLY # Default value
  443. # identifiers of fields in the SQL descriptor
  444. SQL_DESC_COUNT* = 1001
  445. SQL_DESC_TYPE* = 1002
  446. SQL_DESC_LENGTH* = 1003
  447. SQL_DESC_OCTET_LENGTH_PTR* = 1004
  448. SQL_DESC_PRECISION* = 1005
  449. SQL_DESC_SCALE* = 1006
  450. SQL_DESC_DATETIME_INTERVAL_CODE* = 1007
  451. SQL_DESC_NULLABLE* = 1008
  452. SQL_DESC_INDICATOR_PTR* = 1009
  453. SQL_DESC_DATA_PTR* = 1010
  454. SQL_DESC_NAME* = 1011
  455. SQL_DESC_UNNAMED* = 1012
  456. SQL_DESC_OCTET_LENGTH* = 1013
  457. SQL_DESC_ALLOC_TYPE* = 1099 # identifiers of fields in the diagnostics area
  458. SQL_DIAG_RETURNCODE* = 1
  459. SQL_DIAG_NUMBER* = 2
  460. SQL_DIAG_ROW_COUNT* = 3
  461. SQL_DIAG_SQLSTATE* = 4
  462. SQL_DIAG_NATIVE* = 5
  463. SQL_DIAG_MESSAGE_TEXT* = 6
  464. SQL_DIAG_DYNAMIC_FUNCTION* = 7
  465. SQL_DIAG_CLASS_ORIGIN* = 8
  466. SQL_DIAG_SUBCLASS_ORIGIN* = 9
  467. SQL_DIAG_CONNECTION_NAME* = 10
  468. SQL_DIAG_SERVER_NAME* = 11
  469. SQL_DIAG_DYNAMIC_FUNCTION_CODE* = 12 # dynamic function codes
  470. SQL_DIAG_ALTER_TABLE* = 4
  471. SQL_DIAG_CREATE_INDEX* = (- 1)
  472. SQL_DIAG_CREATE_TABLE* = 77
  473. SQL_DIAG_CREATE_VIEW* = 84
  474. SQL_DIAG_DELETE_WHERE* = 19
  475. SQL_DIAG_DROP_INDEX* = (- 2)
  476. SQL_DIAG_DROP_TABLE* = 32
  477. SQL_DIAG_DROP_VIEW* = 36
  478. SQL_DIAG_DYNAMIC_DELETE_CURSOR* = 38
  479. SQL_DIAG_DYNAMIC_UPDATE_CURSOR* = 81
  480. SQL_DIAG_GRANT* = 48
  481. SQL_DIAG_INSERT* = 50
  482. SQL_DIAG_REVOKE* = 59
  483. SQL_DIAG_SELECT_CURSOR* = 85
  484. SQL_DIAG_UNKNOWN_STATEMENT* = 0
  485. SQL_DIAG_UPDATE_WHERE* = 82 # Statement attribute values for cursor sensitivity
  486. SQL_UNSPECIFIED* = 0
  487. SQL_INSENSITIVE* = 1
  488. SQL_SENSITIVE* = 2 # GetTypeInfo() request for all data types
  489. SQL_ALL_TYPES* = 0 # Default conversion code for SQLBindCol(), SQLBindParam() and SQLGetData()
  490. SQL_DEFAULT* = 99 # SQLGetData() code indicating that the application row descriptor
  491. # specifies the data type
  492. SQL_ARD_TYPE* = (- 99) # SQL date/time type subcodes
  493. SQL_CODE_DATE* = 1
  494. SQL_CODE_TIME* = 2
  495. SQL_CODE_TIMESTAMP* = 3 # CLI option values
  496. SQL_FALSE* = 0
  497. SQL_TRUE* = 1 # values of NULLABLE field in descriptor
  498. SQL_NO_NULLS* = 0
  499. SQL_NULLABLE* = 1 # Value returned by SQLGetTypeInfo() to denote that it is
  500. # not known whether or not a data type supports null values.
  501. SQL_NULLABLE_UNKNOWN* = 2
  502. SQL_CLOSE* = 0
  503. SQL_DROP* = 1
  504. SQL_UNBIND* = 2
  505. SQL_RESET_PARAMS* = 3 # Codes used for FetchOrientation in SQLFetchScroll(),
  506. # and in SQLDataSources()
  507. SQL_FETCH_NEXT* = 1
  508. SQL_FETCH_FIRST* = 2
  509. SQL_FETCH_FIRST_USER* = 31
  510. SQL_FETCH_FIRST_SYSTEM* = 32 # Other codes used for FetchOrientation in SQLFetchScroll()
  511. SQL_FETCH_LAST* = 3
  512. SQL_FETCH_PRIOR* = 4
  513. SQL_FETCH_ABSOLUTE* = 5
  514. SQL_FETCH_RELATIVE* = 6
  515. SQL_NULL_HENV* = SqlHEnv(nil)
  516. SQL_NULL_HDBC* = SqlHDBC(nil)
  517. SQL_NULL_HSTMT* = SqlHStmt(nil)
  518. SQL_NULL_HDESC* = SqlHDesc(nil) #* null handle used in place of parent handle when allocating HENV */
  519. SQL_NULL_HANDLE* = SqlHandle(nil) #* Values that may appear in the result set of SQLSpecialColumns() */
  520. SQL_SCOPE_CURROW* = 0
  521. SQL_SCOPE_TRANSACTION* = 1
  522. SQL_SCOPE_SESSION* = 2 #* Column types and scopes in SQLSpecialColumns. */
  523. SQL_BEST_ROWID* = 1
  524. SQL_ROWVER* = 2
  525. SQL_ROW_IDENTIFIER* = 1 #* Reserved values for UNIQUE argument of SQLStatistics() */
  526. SQL_INDEX_UNIQUE* = 0
  527. SQL_INDEX_ALL* = 1 #* Reserved values for RESERVED argument of SQLStatistics() */
  528. SQL_QUICK* = 0
  529. SQL_ENSURE* = 1 #* Values that may appear in the result set of SQLStatistics() */
  530. SQL_TABLE_STAT* = 0
  531. SQL_INDEX_CLUSTERED* = 1
  532. SQL_INDEX_HASHED* = 2
  533. SQL_INDEX_OTHER* = 3
  534. SQL_SCROLL_CONCURRENCY* = 43
  535. SQL_TXN_CAPABLE* = 46
  536. SQL_TRANSACTION_CAPABLE* = SQL_TXN_CAPABLE
  537. SQL_USER_NAME* = 47
  538. SQL_TXN_ISOLATION_OPTION* = 72
  539. SQL_TRANSACTION_ISOLATION_OPTION* = SQL_TXN_ISOLATION_OPTION
  540. SQL_OJ_CAPABILITIES* = 115
  541. SQL_OUTER_JOIN_CAPABILITIES* = SQL_OJ_CAPABILITIES
  542. SQL_XOPEN_CLI_YEAR* = 10000
  543. SQL_CURSOR_SENSITIVITY* = 10001
  544. SQL_DESCRIBE_PARAMETER* = 10002
  545. SQL_CATALOG_NAME* = 10003
  546. SQL_COLLATION_SEQ* = 10004
  547. SQL_MAX_IDENTIFIER_LEN* = 10005
  548. SQL_MAXIMUM_IDENTIFIER_LENGTH* = SQL_MAX_IDENTIFIER_LEN
  549. SQL_SCCO_READ_ONLY* = 1
  550. SQL_SCCO_LOCK* = 2
  551. SQL_SCCO_OPT_ROWVER* = 4
  552. SQL_SCCO_OPT_VALUES* = 8 #* SQL_TXN_CAPABLE values */
  553. SQL_TC_NONE* = 0
  554. SQL_TC_DML* = 1
  555. SQL_TC_ALL* = 2
  556. SQL_TC_DDL_COMMIT* = 3
  557. SQL_TC_DDL_IGNORE* = 4 #* SQL_TXN_ISOLATION_OPTION bitmasks */
  558. SQL_TXN_READ_UNCOMMITTED* = 1
  559. SQL_TRANSACTION_READ_UNCOMMITTED* = SQL_TXN_READ_UNCOMMITTED
  560. SQL_TXN_READ_COMMITTED* = 2
  561. SQL_TRANSACTION_READ_COMMITTED* = SQL_TXN_READ_COMMITTED
  562. SQL_TXN_REPEATABLE_READ* = 4
  563. SQL_TRANSACTION_REPEATABLE_READ* = SQL_TXN_REPEATABLE_READ
  564. SQL_TXN_SERIALIZABLE* = 8
  565. SQL_TRANSACTION_SERIALIZABLE* = SQL_TXN_SERIALIZABLE
  566. SQL_SS_ADDITIONS* = 1
  567. SQL_SS_DELETIONS* = 2
  568. SQL_SS_UPDATES* = 4 # SQLColAttributes defines
  569. SQL_COLUMN_COUNT* = 0
  570. SQL_COLUMN_NAME* = 1
  571. SQL_COLUMN_TYPE* = 2
  572. SQL_COLUMN_LENGTH* = 3
  573. SQL_COLUMN_PRECISION* = 4
  574. SQL_COLUMN_SCALE* = 5
  575. SQL_COLUMN_DISPLAY_SIZE* = 6
  576. SQL_COLUMN_NULLABLE* = 7
  577. SQL_COLUMN_UNSIGNED* = 8
  578. SQL_COLUMN_MONEY* = 9
  579. SQL_COLUMN_UPDATABLE* = 10
  580. SQL_COLUMN_AUTO_INCREMENT* = 11
  581. SQL_COLUMN_CASE_SENSITIVE* = 12
  582. SQL_COLUMN_SEARCHABLE* = 13
  583. SQL_COLUMN_TYPE_NAME* = 14
  584. SQL_COLUMN_TABLE_NAME* = 15
  585. SQL_COLUMN_OWNER_NAME* = 16
  586. SQL_COLUMN_QUALIFIER_NAME* = 17
  587. SQL_COLUMN_LABEL* = 18
  588. SQL_COLATT_OPT_MAX* = SQL_COLUMN_LABEL
  589. SQL_COLUMN_DRIVER_START* = 1000
  590. SQL_DESC_ARRAY_SIZE* = 20
  591. SQL_DESC_ARRAY_STATUS_PTR* = 21
  592. SQL_DESC_AUTO_UNIQUE_VALUE* = SQL_COLUMN_AUTO_INCREMENT
  593. SQL_DESC_BASE_COLUMN_NAME* = 22
  594. SQL_DESC_BASE_TABLE_NAME* = 23
  595. SQL_DESC_BIND_OFFSET_PTR* = 24
  596. SQL_DESC_BIND_TYPE* = 25
  597. SQL_DESC_CASE_SENSITIVE* = SQL_COLUMN_CASE_SENSITIVE
  598. SQL_DESC_CATALOG_NAME* = SQL_COLUMN_QUALIFIER_NAME
  599. SQL_DESC_CONCISE_TYPE* = SQL_COLUMN_TYPE
  600. SQL_DESC_DATETIME_INTERVAL_PRECISION* = 26
  601. SQL_DESC_DISPLAY_SIZE* = SQL_COLUMN_DISPLAY_SIZE
  602. SQL_DESC_FIXED_PREC_SCALE* = SQL_COLUMN_MONEY
  603. SQL_DESC_LABEL* = SQL_COLUMN_LABEL
  604. SQL_DESC_LITERAL_PREFIX* = 27
  605. SQL_DESC_LITERAL_SUFFIX* = 28
  606. SQL_DESC_LOCAL_TYPE_NAME* = 29
  607. SQL_DESC_MAXIMUM_SCALE* = 30
  608. SQL_DESC_MINIMUM_SCALE* = 31
  609. SQL_DESC_NUM_PREC_RADIX* = 32
  610. SQL_DESC_PARAMETER_TYPE* = 33
  611. SQL_DESC_ROWS_PROCESSED_PTR* = 34
  612. SQL_DESC_SCHEMA_NAME* = SQL_COLUMN_OWNER_NAME
  613. SQL_DESC_SEARCHABLE* = SQL_COLUMN_SEARCHABLE
  614. SQL_DESC_TYPE_NAME* = SQL_COLUMN_TYPE_NAME
  615. SQL_DESC_TABLE_NAME* = SQL_COLUMN_TABLE_NAME
  616. SQL_DESC_UNSIGNED* = SQL_COLUMN_UNSIGNED
  617. SQL_DESC_UPDATABLE* = SQL_COLUMN_UPDATABLE #* SQLEndTran() options */
  618. SQL_COMMIT* = 0
  619. SQL_ROLLBACK* = 1
  620. SQL_ATTR_ROW_ARRAY_SIZE* = 27 #* SQLConfigDataSource() options */
  621. ODBC_ADD_DSN* = 1
  622. ODBC_CONFIG_DSN* = 2
  623. ODBC_REMOVE_DSN* = 3
  624. ODBC_ADD_SYS_DSN* = 4
  625. ODBC_CONFIG_SYS_DSN* = 5
  626. ODBC_REMOVE_SYS_DSN* = 6
  627. SQL_ACTIVE_CONNECTIONS* = 0 # SQLGetInfo
  628. SQL_DATA_SOURCE_NAME* = 2
  629. SQL_DATA_SOURCE_READ_ONLY* = 25
  630. SQL_DATABASE_NAME* = 2
  631. SQL_DBMS_NAME* = 17
  632. SQL_DBMS_VERSION* = 18
  633. SQL_DRIVER_HDBC* = 3
  634. SQL_DRIVER_HENV* = 4
  635. SQL_DRIVER_HSTMT* = 5
  636. SQL_DRIVER_NAME* = 6
  637. SQL_DRIVER_VER* = 7
  638. SQL_FETCH_DIRECTION* = 8
  639. SQL_ODBC_VER* = 10
  640. SQL_DRIVER_ODBC_VER* = 77
  641. SQL_SERVER_NAME* = 13
  642. SQL_ACTIVE_ENVIRONMENTS* = 116
  643. SQL_ACTIVE_STATEMENTS* = 1
  644. SQL_SQL_CONFORMANCE* = 118
  645. SQL_DATETIME_LITERALS* = 119
  646. SQL_ASYNC_MODE* = 10021
  647. SQL_BATCH_ROW_COUNT* = 120
  648. SQL_BATCH_SUPPORT* = 121
  649. SQL_CATALOG_LOCATION* = 114
  650. #SQL_CATALOG_NAME* = 10003
  651. SQL_CATALOG_NAME_SEPARATOR* = 41
  652. SQL_CATALOG_TERM* = 42
  653. SQL_CATALOG_USAGE* = 92
  654. #SQL_COLLATION_SEQ* = 10004
  655. SQL_COLUMN_ALIAS* = 87
  656. #SQL_USER_NAME* = 47
  657. proc SQLAllocHandle*(HandleType: TSqlSmallInt, InputHandle: SqlHandle,
  658. OutputHandlePtr: var SqlHandle): TSqlSmallInt{.
  659. dynlib: odbclib, importc.}
  660. proc SQLSetEnvAttr*(EnvironmentHandle: SqlHEnv, Attribute: TSqlInteger,
  661. Value: TSqlInteger, StringLength: TSqlInteger): TSqlSmallInt{.
  662. dynlib: odbclib, importc.}
  663. proc SQLGetEnvAttr*(EnvironmentHandle: SqlHEnv, Attribute: TSqlInteger,
  664. Value: SqlPointer, BufferLength: TSqlInteger,
  665. StringLength: PSQLINTEGER): TSqlSmallInt{.dynlib: odbclib,
  666. importc.}
  667. proc SQLFreeHandle*(HandleType: TSqlSmallInt, Handle: SqlHandle): TSqlSmallInt{.
  668. dynlib: odbclib, importc.}
  669. proc SQLGetDiagRec*(HandleType: TSqlSmallInt, Handle: SqlHandle,
  670. RecNumber: TSqlSmallInt, Sqlstate: PSQLCHAR,
  671. NativeError: var TSqlInteger, MessageText: PSQLCHAR,
  672. BufferLength: TSqlSmallInt, TextLength: var TSqlSmallInt): TSqlSmallInt{.
  673. dynlib: odbclib, importc.}
  674. proc SQLGetDiagField*(HandleType: TSqlSmallInt, Handle: SqlHandle,
  675. RecNumber: TSqlSmallInt, DiagIdentifier: TSqlSmallInt,
  676. DiagInfoPtr: SqlPointer, BufferLength: TSqlSmallInt,
  677. StringLengthPtr: var TSqlSmallInt): TSqlSmallInt{.
  678. dynlib: odbclib, importc.}
  679. proc SQLConnect*(ConnectionHandle: SqlHDBC, ServerName: PSQLCHAR,
  680. NameLength1: TSqlSmallInt, UserName: PSQLCHAR,
  681. NameLength2: TSqlSmallInt, Authentication: PSQLCHAR,
  682. NameLength3: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib, importc.}
  683. proc SQLDisconnect*(ConnectionHandle: SqlHDBC): TSqlSmallInt{.dynlib: odbclib,
  684. importc.}
  685. proc SQLDriverConnect*(hdbc: SqlHDBC, hwnd: SqlHWND, szCsin: cstring,
  686. szCLen: TSqlSmallInt, szCsout: cstring,
  687. cbCSMax: TSqlSmallInt, cbCsOut: var TSqlSmallInt,
  688. f: SqlUSmallInt): TSqlSmallInt{.dynlib: odbclib, importc.}
  689. proc SQLBrowseConnect*(hdbc: SqlHDBC, szConnStrIn: PSQLCHAR,
  690. cbConnStrIn: TSqlSmallInt, szConnStrOut: PSQLCHAR,
  691. cbConnStrOutMax: TSqlSmallInt,
  692. cbConnStrOut: var TSqlSmallInt): TSqlSmallInt{.
  693. dynlib: odbclib, importc.}
  694. proc SQLExecDirect*(StatementHandle: SqlHStmt, StatementText: PSQLCHAR,
  695. TextLength: TSqlInteger): TSqlSmallInt{.dynlib: odbclib, importc.}
  696. proc SQLExecDirectW*(StatementHandle: SqlHStmt, StatementText: WideCString,
  697. TextLength: TSqlInteger): TSqlSmallInt{.dynlib: odbclib, importc.}
  698. proc SQLPrepare*(StatementHandle: SqlHStmt, StatementText: PSQLCHAR,
  699. TextLength: TSqlInteger): TSqlSmallInt{.dynlib: odbclib, importc.}
  700. proc SQLPrepareW*(StatementHandle: SqlHStmt, StatementText: WideCString,
  701. TextLength: TSqlInteger): TSqlSmallInt{.dynlib: odbclib, importc.}
  702. proc SQLCloseCursor*(StatementHandle: SqlHStmt): TSqlSmallInt{.dynlib: odbclib,
  703. importc.}
  704. proc SQLExecute*(StatementHandle: SqlHStmt): TSqlSmallInt{.dynlib: odbclib, importc.}
  705. proc SQLFetch*(StatementHandle: SqlHStmt): TSqlSmallInt{.dynlib: odbclib, importc.}
  706. proc SQLNumResultCols*(StatementHandle: SqlHStmt, ColumnCount: var TSqlSmallInt): TSqlSmallInt{.
  707. dynlib: odbclib, importc.}
  708. proc SQLDescribeCol*(StatementHandle: SqlHStmt, ColumnNumber: SqlUSmallInt,
  709. ColumnName: PSQLCHAR, BufferLength: TSqlSmallInt,
  710. NameLength: var TSqlSmallInt, DataType: var TSqlSmallInt,
  711. ColumnSize: var SqlUInteger,
  712. DecimalDigits: var TSqlSmallInt, Nullable: var TSqlSmallInt): TSqlSmallInt{.
  713. dynlib: odbclib, importc.}
  714. proc SQLFetchScroll*(StatementHandle: SqlHStmt, FetchOrientation: TSqlSmallInt,
  715. FetchOffset: TSqlInteger): TSqlSmallInt{.dynlib: odbclib,
  716. importc.}
  717. proc SQLExtendedFetch*(hstmt: SqlHStmt, fFetchType: SqlUSmallInt,
  718. irow: TSqlInteger, pcrow: PSQLUINTEGER,
  719. rgfRowStatus: PSQLUSMALLINT): TSqlSmallInt{.dynlib: odbclib,
  720. importc.}
  721. proc SQLGetData*(StatementHandle: SqlHStmt, ColumnNumber: SqlUSmallInt,
  722. TargetType: TSqlSmallInt, TargetValue: SqlPointer,
  723. BufferLength: TSqlInteger, StrLen_or_Ind: PSQLINTEGER): TSqlSmallInt{.
  724. dynlib: odbclib, importc.}
  725. proc SQLSetStmtAttr*(StatementHandle: SqlHStmt, Attribute: TSqlInteger,
  726. Value: SqlPointer, StringLength: TSqlInteger): TSqlSmallInt{.
  727. dynlib: odbclib, importc.}
  728. proc SQLGetStmtAttr*(StatementHandle: SqlHStmt, Attribute: TSqlInteger,
  729. Value: SqlPointer, BufferLength: TSqlInteger,
  730. StringLength: PSQLINTEGER): TSqlSmallInt{.dynlib: odbclib,
  731. importc.}
  732. proc SQLGetInfo*(ConnectionHandle: SqlHDBC, InfoType: SqlUSmallInt,
  733. InfoValue: SqlPointer, BufferLength: TSqlSmallInt,
  734. StringLength: PSQLSMALLINT): TSqlSmallInt{.dynlib: odbclib,
  735. importc.}
  736. proc SQLBulkOperations*(StatementHandle: SqlHStmt, Operation: TSqlSmallInt): TSqlSmallInt{.
  737. dynlib: odbclib, importc.}
  738. proc SQLPutData*(StatementHandle: SqlHStmt, Data: SqlPointer,
  739. StrLen_or_Ind: TSqlInteger): TSqlSmallInt{.dynlib: odbclib, importc.}
  740. proc SQLBindCol*(StatementHandle: SqlHStmt, ColumnNumber: SqlUSmallInt,
  741. TargetType: TSqlSmallInt, TargetValue: SqlPointer,
  742. BufferLength: TSqlInteger, StrLen_or_Ind: PSQLINTEGER): TSqlSmallInt{.
  743. dynlib: odbclib, importc.}
  744. proc SQLSetPos*(hstmt: SqlHStmt, irow: SqlUSmallInt, fOption: SqlUSmallInt,
  745. fLock: SqlUSmallInt): TSqlSmallInt{.dynlib: odbclib, importc.}
  746. proc SQLDataSources*(EnvironmentHandle: SqlHEnv, Direction: SqlUSmallInt,
  747. ServerName: PSQLCHAR, BufferLength1: TSqlSmallInt,
  748. NameLength1: PSQLSMALLINT, Description: PSQLCHAR,
  749. BufferLength2: TSqlSmallInt, NameLength2: PSQLSMALLINT): TSqlSmallInt{.
  750. dynlib: odbclib, importc.}
  751. proc SQLDrivers*(EnvironmentHandle: SqlHEnv, Direction: SqlUSmallInt,
  752. DriverDescription: PSQLCHAR, BufferLength1: TSqlSmallInt,
  753. DescriptionLength1: PSQLSMALLINT, DriverAttributes: PSQLCHAR,
  754. BufferLength2: TSqlSmallInt, AttributesLength2: PSQLSMALLINT): TSqlSmallInt{.
  755. dynlib: odbclib, importc.}
  756. proc SQLSetConnectAttr*(ConnectionHandle: SqlHDBC, Attribute: TSqlInteger,
  757. Value: SqlPointer, StringLength: TSqlInteger): TSqlSmallInt{.
  758. dynlib: odbclib, importc.}
  759. proc SQLGetCursorName*(StatementHandle: SqlHStmt, CursorName: PSQLCHAR,
  760. BufferLength: TSqlSmallInt, NameLength: PSQLSMALLINT): TSqlSmallInt{.
  761. dynlib: odbclib, importc.}
  762. proc SQLSetCursorName*(StatementHandle: SqlHStmt, CursorName: PSQLCHAR,
  763. NameLength: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib,
  764. importc.}
  765. proc SQLRowCount*(StatementHandle: SqlHStmt, RowCount: var TSqlInteger): TSqlSmallInt{.
  766. dynlib: odbclib, importc.}
  767. proc SQLBindParameter*(hstmt: SqlHStmt, ipar: SqlUSmallInt,
  768. fParamType: TSqlSmallInt, fCType: TSqlSmallInt,
  769. fSqlType: TSqlSmallInt, cbColDef: SqlUInteger,
  770. ibScale: TSqlSmallInt, rgbValue: SqlPointer,
  771. cbValueMax: TSqlInteger, pcbValue: PSQLINTEGER): TSqlSmallInt{.
  772. dynlib: odbclib, importc.}
  773. proc SQLFreeStmt*(StatementHandle: SqlHStmt, Option: SqlUSmallInt): TSqlSmallInt{.
  774. dynlib: odbclib, importc.}
  775. proc SQLColAttribute*(StatementHandle: SqlHStmt, ColumnNumber: SqlUSmallInt,
  776. FieldIdentifier: SqlUSmallInt,
  777. CharacterAttribute: PSQLCHAR, BufferLength: TSqlSmallInt,
  778. StringLength: PSQLSMALLINT,
  779. NumericAttribute: SqlPointer): TSqlSmallInt{.
  780. dynlib: odbclib, importc.}
  781. proc SQLEndTran*(HandleType: TSqlSmallInt, Handle: SqlHandle,
  782. CompletionType: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib,
  783. importc.}
  784. proc SQLTables*(hstmt: SqlHStmt, szTableQualifier: PSQLCHAR,
  785. cbTableQualifier: TSqlSmallInt, szTableOwner: PSQLCHAR,
  786. cbTableOwner: TSqlSmallInt, szTableName: PSQLCHAR,
  787. cbTableName: TSqlSmallInt, szTableType: PSQLCHAR,
  788. cbTableType: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib, importc.}
  789. proc SQLColumns*(hstmt: SqlHStmt, szTableQualifier: PSQLCHAR,
  790. cbTableQualifier: TSqlSmallInt, szTableOwner: PSQLCHAR,
  791. cbTableOwner: TSqlSmallInt, szTableName: PSQLCHAR,
  792. cbTableName: TSqlSmallInt, szColumnName: PSQLCHAR,
  793. cbColumnName: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib, importc.}
  794. proc SQLSpecialColumns*(StatementHandle: SqlHStmt, IdentifierType: SqlUSmallInt,
  795. CatalogName: PSQLCHAR, NameLength1: TSqlSmallInt,
  796. SchemaName: PSQLCHAR, NameLength2: TSqlSmallInt,
  797. TableName: PSQLCHAR, NameLength3: TSqlSmallInt,
  798. Scope: SqlUSmallInt,
  799. Nullable: SqlUSmallInt): TSqlSmallInt{.
  800. dynlib: odbclib, importc.}
  801. proc SQLProcedures*(hstmt: SqlHStmt, szTableQualifier: PSQLCHAR,
  802. cbTableQualifier: TSqlSmallInt, szTableOwner: PSQLCHAR,
  803. cbTableOwner: TSqlSmallInt, szTableName: PSQLCHAR,
  804. cbTableName: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib,
  805. importc.}
  806. proc SQLPrimaryKeys*(hstmt: SqlHStmt, CatalogName: PSQLCHAR,
  807. NameLength1: TSqlSmallInt, SchemaName: PSQLCHAR,
  808. NameLength2: TSqlSmallInt, TableName: PSQLCHAR,
  809. NameLength3: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib,
  810. importc.}
  811. proc SQLProcedureColumns*(hstmt: SqlHStmt, CatalogName: PSQLCHAR,
  812. NameLength1: TSqlSmallInt, SchemaName: PSQLCHAR,
  813. NameLength2: TSqlSmallInt, ProcName: PSQLCHAR,
  814. NameLength3: TSqlSmallInt, ColumnName: PSQLCHAR,
  815. NameLength4: TSqlSmallInt): TSqlSmallInt{.dynlib: odbclib,
  816. importc.}
  817. proc SQLStatistics*(hstmt: SqlHStmt, CatalogName: PSQLCHAR,
  818. NameLength1: TSqlSmallInt, SchemaName: PSQLCHAR,
  819. NameLength2: TSqlSmallInt, TableName: PSQLCHAR,
  820. NameLength3: TSqlSmallInt, Unique: SqlUSmallInt,
  821. Reserved: SqlUSmallInt): TSqlSmallInt {.
  822. dynlib: odbclib, importc.}
  823. proc SQLErr*(henv: SqlHEnv, hdbc: SqlHDBC, hstmt: SqlHStmt,
  824. szSqlState, pfNativeError, szErrorMsg: PSQLCHAR,
  825. cbErrorMsgMax: TSqlSmallInt,
  826. pcbErrorMsg: PSQLINTEGER): TSqlSmallInt {.
  827. dynlib: odbclib, importc: "SQLError".}
  828. {.pop.}