]> git.saurik.com Git - wxWidgets.git/blob - src/iodbc/isqlext.h
ODBC updates
[wxWidgets.git] / src / iodbc / isqlext.h
1 #ifndef _INTRINSIC_SQLEXT_H
2 # define _INTRINSIC_SQLEXT_H
3
4 # include <isql.h>
5
6 # define SQL_STILL_EXECUTING 2
7 # define SQL_NEED_DATA 99
8
9 /* extend SQL datatypes */
10 # define SQL_DATE 9
11 # define SQL_TIME 10
12 # define SQL_TIMESTAMP 11
13 # define SQL_LONGVARCHAR (-1)
14 # define SQL_BINARY (-2)
15 # define SQL_VARBINARY (-3)
16 # define SQL_LONGVARBINARY (-4)
17 # define SQL_BIGINT (-5)
18 # define SQL_TINYINT (-6)
19 # define SQL_BIT (-7) /* conflict with SQL3 ??? */
20 # define SQL_TYPE_DRIVER_START (-80)
21
22 /* C to SQL datatype mapping */
23 # define SQL_C_DATE SQL_DATE
24 # define SQL_C_TIME SQL_TIME
25 # define SQL_C_TIMESTAMP SQL_TIMESTAMP
26 # define SQL_C_BINARY SQL_BINARY
27 # define SQL_C_BIT SQL_BIT
28 # define SQL_C_TINYINT SQL_TINYINT
29
30 # define SQL_SIGNED_OFFSET (-20)
31 # define SQL_UNSIGNED_OFFSET (-22)
32
33 # define SQL_C_SLONG (SQL_C_LONG + SQL_SIGNED_OFFSET)
34 # define SQL_C_SSHORT (SQL_C_SHORT + SQL_SIGNED_OFFSET)
35 # define SQL_C_STINYINT (SQL_TINYINT + SQL_SIGNED_OFFSET)
36 # define SQL_C_ULONG (SQL_C_LONG + SQL_UNSIGNED_OFFSET)
37 # define SQL_C_USHORT (SQL_C_SHORT + SQL_UNSIGNED_OFFSET)
38 # define SQL_C_UTINYINT (SQL_TINYINT + SQL_UNSIGNED_OFFSET)
39 # define SQL_C_BOOKMARK SQL_C_ULONG
40
41 # if defined(SQL_TYPE_MIN)
42 # undef SQL_TYPE_MIN
43 # define SQL_TYPE_MIN SQL_BIT
44 /* Note:If SQL_BIT uses SQL3 value (i.e. 14) then,
45 * SQL_TYPE_MIN need to be defined as SQL_TINYINT
46 * (i.e. -6).
47 */
48 # endif
49
50 # define SQL_ALL_TYPES 0
51
52 /* SQLDriverConnect flag values */
53 # define SQL_DRIVER_NOPROMPT 0
54 # define SQL_DRIVER_COMPLETE 1
55 # define SQL_DRIVER_PROMPT 2
56 # define SQL_DRIVER_COMPLETE_REQUIRED 3
57
58 /* SQLSetParam extensions */
59 # define SQL_DEFAULT_PARAM (-5)
60 # define SQL_IGNORE (-6)
61
62 /* function number for SQLGetFunctions and _iodbcdm_getproc */
63 # define SQL_API_SQLALLOCCONNECT 1
64 # define SQL_API_SQLALLOCENV 2
65 # define SQL_API_SQLALLOCSTMT 3
66 # define SQL_API_SQLBINDCOL 4
67 # define SQL_API_SQLCANCEL 5
68 # define SQL_API_SQLCOLATTRIBUTES 6
69 # define SQL_API_SQLCONNECT 7
70 # define SQL_API_SQLDESCRIBECOL 8
71 # define SQL_API_SQLDISCONNECT 9
72 # define SQL_API_SQLERROR 10
73 # define SQL_API_SQLEXECDIRECT 11
74 # define SQL_API_SQLEXECUTE 12
75 # define SQL_API_SQLFETCH 13
76 # define SQL_API_SQLFREECONNECT 14
77 # define SQL_API_SQLFREEENV 15
78 # define SQL_API_SQLFREESTMT 16
79 # define SQL_API_SQLGETCURSORNAME 17
80 # define SQL_API_SQLNUMRESULTCOLS 18
81 # define SQL_API_SQLPREPARE 19
82 # define SQL_API_SQLROWCOUNT 20
83 # define SQL_API_SQLSETCURSORNAME 21
84 # define SQL_API_SQLSETPARAM 22
85 # define SQL_API_SQLTRANSACT 23
86
87 # define SQL_NUM_FUNCTIONS 23
88
89 # define SQL_EXT_API_START 40
90
91 # define SQL_API_SQLCOLUMNS 40
92
93 # define SQL_API_SQLDRIVERCONNECT 41
94 # define SQL_API_SQLGETCONNECTOPTION 42
95 # define SQL_API_SQLGETDATA 43
96 # define SQL_API_SQLGETFUNCTIONS 44
97 # define SQL_API_SQLGETINFO 45
98 # define SQL_API_SQLGETSTMTOPTION 46
99 # define SQL_API_SQLGETTYPEINFO 47
100 # define SQL_API_SQLPARAMDATA 48
101 # define SQL_API_SQLPUTDATA 49
102 # define SQL_API_SQLSETCONNECTOPTION 50
103 # define SQL_API_SQLSETSTMTOPTION 51
104 # define SQL_API_SQLSPECIALCOLUMNS 52
105 # define SQL_API_SQLSTATISTICS 53
106 # define SQL_API_SQLTABLES 54
107
108 # define SQL_API_SQLBROWSECONNECT 55
109 # define SQL_API_SQLCOLUMNPRIVILEGES 56
110 # define SQL_API_SQLDATASOURCES 57
111 # define SQL_API_SQLDESCRIBEPARAM 58
112 # define SQL_API_SQLEXTENDEDFETCH 59
113 # define SQL_API_SQLFOREIGNKEYS 60
114 # define SQL_API_SQLMORERESULTS 61
115 # define SQL_API_SQLNATIVESQL 62
116 # define SQL_API_SQLNUMPARAMS 63
117 # define SQL_API_SQLPARAMOPTIONS 64
118 # define SQL_API_SQLPRIMARYKEYS 65
119 # define SQL_API_SQLPROCEDURECOLUMNS 66
120 # define SQL_API_SQLPROCEDURES 67
121 # define SQL_API_SQLSETPOS 68
122 # define SQL_API_SQLSETSCROLLOPTIONS 69
123 # define SQL_API_SQLTABLEPRIVILEGES 70
124
125 # define SQL_API_SQLDRIVERS 71
126 # define SQL_API_SQLBINDPARAMETER 72
127 # define SQL_EXT_API_LAST SQL_API_SQLBINDPARAMETER
128
129 # define SQL_API_ALL_FUNCTIONS 0
130
131 /* SQLGetInfo infor number */
132 # define SQL_INFO_FIRST 0
133 # define SQL_DRIVER_HDBC 3
134 # define SQL_DRIVER_HENV 4
135 # define SQL_DRIVER_HSTMT 5
136 # define SQL_DRIVER_NAME 6
137 # define SQL_ODBC_VER 10
138 # define SQL_CURSOR_COMMIT_BEHAVIOR 23
139 # define SQL_CURSOR_ROLLBACK_BEHAVIOR 24
140 # define SQL_DEFAULT_TXN_ISOLATION 26
141
142 # define SQL_TXN_ISOLATION_OPTION 72
143 # define SQL_NON_NULLABLE_COLUMNS 75
144
145 # define SQL_DRIVER_HLIB 76
146 # define SQL_DRIVER_ODBC_VER 77
147
148 # define SQL_QUALIFIER_LOCATION 114
149
150 # define SQL_INFO_LAST SQL_QUALIFIER_LOCATION
151
152 # define SQL_INFO_DRIVER_START 1000
153
154
155 /* SQL_TXN_ISOLATION_OPTION masks */
156 # define SQL_TXN_READ_UNCOMMITTED 0x00000001L
157 # define SQL_TXN_READ_COMMITTED 0x00000002L
158 # define SQL_TXN_REPEATABLE_READ 0x00000004L
159 # define SQL_TXN_SERIALIZABLE 0x00000008L
160 # define SQL_TXN_VERSIONING 0x00000010L
161
162 /* SQL_CURSOR_COMMIT_BEHAVIOR and SQL_CURSOR_ROLLBACK_BEHAVIOR values */
163
164 # define SQL_CB_DELETE 0x0000
165 # define SQL_CB_CLOSE 0x0001
166 # define SQL_CB_PRESERVE 0x0002
167
168 /* options for SQLGetStmtOption/SQLSetStmtOption */
169 # define SQL_QUERY_TIMEOUT 0
170 # define SQL_MAX_ROWS 1
171 # define SQL_NOSCAN 2
172 # define SQL_MAX_LENGTH 3
173 # define SQL_ASYNC_ENABLE 4
174 # define SQL_BIND_TYPE 5
175 # define SQL_CURSOR_TYPE 6
176 # define SQL_CONCURRENCY 7
177 # define SQL_KEYSET_SIZE 8
178 # define SQL_ROWSET_SIZE 9
179 # define SQL_SIMULATE_CURSOR 10
180 # define SQL_RETRIEVE_DATA 11
181 # define SQL_USE_BOOKMARKS 12
182 # define SQL_GET_BOOKMARK 13 /* GetStmtOption Only */
183 # define SQL_ROW_NUMBER 14 /* GetStmtOption Only */
184 # define SQL_STMT_OPT_MAX SQL_ROW_NUMBER
185
186 # define SQL_STMT_OPT_MIN SQL_QUERY_TIMEOUT
187
188
189 /* SQL_QUERY_TIMEOUT options */
190 # define SQL_QUERY_TIMEOUT_DEFAULT 0UL
191
192 /* SQL_MAX_ROWS options */
193 # define SQL_MAX_ROWS_DEFAULT 0UL
194
195 /* SQL_MAX_LENGTH options */
196 # define SQL_MAX_LENGTH_DEFAULT 0UL
197
198 /* SQL_CONCURRENCY options */
199 # define SQL_CONCUR_READ_ONLY 1
200 # define SQL_CONCUR_LOCK 2
201 # define SQL_CONCUR_ROWVER 3
202 # define SQL_CONCUR_VALUES 4
203
204 /* SQL_CURSOR_TYPE options */
205 #define SQL_CURSOR_FORWARD_ONLY 0UL
206 #define SQL_CURSOR_KEYSET_DRIVEN 1UL
207 #define SQL_CURSOR_DYNAMIC 2UL
208 #define SQL_CURSOR_STATIC 3UL
209 #define SQL_CURSOR_TYPE_DEFAULT SQL_CURSOR_FORWARD_ONLY
210
211 /* options for SQLSetConnectOption/SQLGetConnectOption */
212 # define SQL_ACCESS_MODE 101
213 # define SQL_AUTOCOMMIT 102
214 # define SQL_LOGIN_TIMEOUT 103
215 # define SQL_OPT_TRACE 104
216 # define SQL_OPT_TRACEFILE 105
217 # define SQL_TRANSLATE_DLL 106
218 # define SQL_TRANSLATE_OPTION 107
219 # define SQL_TXN_ISOLATION 108
220 # define SQL_CURRENT_QUALIFIER 109
221 # define SQL_ODBC_CURSORS 110
222 # define SQL_QUIET_MODE 111
223 # define SQL_PACKET_SIZE 112
224 # define SQL_CONN_OPT_MAX SQL_PACKET_SIZE
225 # define SQL_CONNECT_OPT_DRVR_START 1000
226
227 # define SQL_CONN_OPT_MIN SQL_ACCESS_MODE
228
229 /* SQL_ACCESS_MODE options */
230 # define SQL_MODE_READ_WRITE 0UL
231 # define SQL_MODE_READ_ONLY 1UL
232 # define SQL_MODE_DEFAULT SQL_MODE_READ_WRITE
233
234 /* SQL_AUTOCOMMIT options */
235 # define SQL_AUTOCOMMIT_OFF 0UL
236 # define SQL_AUTOCOMMIT_ON 1UL
237 # define SQL_AUTOCOMMIT_DEFAULT SQL_AUTOCOMMIT_ON
238
239 /* SQL_LOGIN_TIMEOUT options */
240 # define SQL_LOGIN_TIMEOUT_DEFAULT 15UL
241
242 /* SQL_OPT_TRACE options */
243 # define SQL_OPT_TRACE_OFF 0UL
244 # define SQL_OPT_TRACE_ON 1UL
245 # define SQL_OPT_TRACE_DEFAULT SQL_OPT_TRACE_OFF
246 # define SQL_OPT_TRACE_FILE_DEFAULT "odbc.log"
247
248 /* SQL_ODBC_CURSORS options */
249 # define SQL_CUR_USE_IF_NEEDED 0UL
250 # define SQL_CUR_USE_ODBC 1UL
251 # define SQL_CUR_USE_DRIVER 2UL
252 # define SQL_CUR_DEFAULT SQL_CUR_USE_DRIVER
253
254 /* Column types and scopes in SQLSpecialColumns. */
255 # define SQL_BEST_ROWID 1
256 # define SQL_ROWVER 2
257
258 # define SQL_SCOPE_CURROW 0
259 # define SQL_SCOPE_TRANSACTION 1
260 # define SQL_SCOPE_SESSION 2
261
262 /* Operations in SQLSetPos */
263 # define SQL_ADD 4
264
265 /* Lock options in SQLSetPos */
266 # define SQL_LOCK_NO_CHANGE 0
267 # define SQL_LOCK_EXCLUSIVE 1
268 # define SQL_LOCK_UNLOCK 2
269
270 /* SQLExtendedFetch flag values */
271 # define SQL_FETCH_NEXT 1
272 # define SQL_FETCH_FIRST 2
273 # define SQL_FETCH_LAST 3
274 # define SQL_FETCH_PRIOR 4
275 # define SQL_FETCH_ABSOLUTE 5
276 # define SQL_FETCH_RELATIVE 6
277 # define SQL_FETCH_BOOKMARK 8
278
279 /* Defines for SQLBindParameter/SQLProcedureColumns */
280 # define SQL_PARAM_TYPE_UNKNOWN 0
281 # define SQL_PARAM_INPUT 1
282 # define SQL_PARAM_INPUT_OUTPUT 2
283 # define SQL_RESULT_COL 3
284 # define SQL_PARAM_OUTPUT 4
285
286 /* Defines used by Driver Manager for mapping SQLSetParam to SQLBindParameter */
287 # define SQL_PARAM_TYPE_DEFAULT SQL_PARAM_INPUT_OUTPUT
288 # define SQL_SETPARAM_VALUE_MAX (-1L)
289
290 /* SQLStatistics flag values */
291 # define SQL_INDEX_UNIQUE 0
292 # define SQL_INDEX_ALL 1
293
294 # define SQL_QUICK 0
295 # define SQL_ENSURE 1
296
297 /* SQLSetScrollOption flag values */
298 # define SQL_SCROLL_FORWARD_ONLY 0L
299 # define SQL_SCROLL_KEYSET_DRIVEN (-1L)
300 # define SQL_SCROLL_DYNAMIC (-2L)
301 # define SQL_SCROLL_STATIC (-3L)
302
303 # if defined(__cplusplus) || defined(__IBMCPP__)
304 extern "C" {
305 # endif
306
307 RETCODE SQL_API SQLSetConnectOption (HDBC, UWORD, UDWORD);
308 RETCODE SQL_API SQLNumResultCols ( HSTMT, SWORD FAR* );
309
310 # if defined(__cplusplus) || defined(__IBMCPP__)
311 }
312 # endif
313
314 #endif