mtollari 63d98e39cd Patch level : 12.0 no-patch
Files correlati     : 
Commento            : 
- Creazione nuova cartella per contenere tutte le librerie esterne
- Aggiunta nuova libreria sqlapi per interfacciare campo a vari DB

git-svn-id: svn://10.65.10.50/branches/R_10_00@24149 c028cbd2-c16b-5b4b-a496-9718f37d4682
2017-10-26 09:07:39 +00:00

1550 lines
60 KiB
C

/******************************************************************************
*
* Source File Name = sqlcli1.h
*
* (C) COPYRIGHT International Business Machines Corp. 1993, 2004
* All Rights Reserved
* Licensed Materials - Property of IBM
*
* US Government Users Restricted Rights - Use, duplication or
* disclosure restricted by GSA ADP Schedule Contract with IBM Corp.
*
* Function = Include File defining:
* DB2 CLI Interface - Constants
* DB2 CLI Interface - Function Prototypes
*
* Operating System = Common C Include File
*
*****************************************************************************/
#ifndef SQL_H_SQLCLI1
#define SQL_H_SQLCLI1 /* Permit duplicate Includes */
/* Prevent inclusion of winsock.h in windows.h */
#ifndef _WINSOCKAPI_
#define _WINSOCKAPI_
#define DB2_WINSOCKAPI_
#endif
/* ODBC64 should be used instead of CLI_WIN64 for linking with libdb2o.dll */
#ifndef ODBC64
#ifdef CLI_WIN64
#define ODBC64
#endif
#endif
#include "sqlsystm.h" /* System dependent defines */
#if defined(DB2NT)
#include <windows.h>
#endif
#include "sqlca.h"
#include "sqlcli.h"
#ifdef __cplusplus
extern "C" {
#endif
/* SQLGetFunction defines - supported functions */
#define SQL_API_SQLALLOCCONNECT 1
#define SQL_API_SQLALLOCENV 2
#define SQL_API_SQLALLOCSTMT 3
#define SQL_API_SQLBINDCOL 4
#define SQL_API_SQLBINDPARAM 1002
#define SQL_API_SQLCANCEL 5
#define SQL_API_SQLCONNECT 7
#define SQL_API_SQLCOPYDESC 1004
#define SQL_API_SQLDESCRIBECOL 8
#define SQL_API_SQLDISCONNECT 9
#define SQL_API_SQLERROR 10
#define SQL_API_SQLEXECDIRECT 11
#define SQL_API_SQLEXECUTE 12
#define SQL_API_SQLFETCH 13
#define SQL_API_SQLFREECONNECT 14
#define SQL_API_SQLFREEENV 15
#define SQL_API_SQLFREESTMT 16
#define SQL_API_SQLGETCURSORNAME 17
#define SQL_API_SQLNUMRESULTCOLS 18
#define SQL_API_SQLPREPARE 19
#define SQL_API_SQLROWCOUNT 20
#define SQL_API_SQLSETCURSORNAME 21
#define SQL_API_SQLSETDESCFIELD 1017
#define SQL_API_SQLSETDESCREC 1018
#define SQL_API_SQLSETENVATTR 1019
#define SQL_API_SQLSETPARAM 22
#define SQL_API_SQLTRANSACT 23
#define SQL_API_SQLCOLUMNS 40
#define SQL_API_SQLGETCONNECTOPTION 42
#define SQL_API_SQLGETDATA 43
#define SQL_API_SQLGETDATAINTERNAL 174
#define SQL_API_SQLGETDESCFIELD 1008
#define SQL_API_SQLGETDESCREC 1009
#define SQL_API_SQLGETDIAGFIELD 1010
#define SQL_API_SQLGETDIAGREC 1011
#define SQL_API_SQLGETENVATTR 1012
#define SQL_API_SQLGETFUNCTIONS 44
#define SQL_API_SQLGETINFO 45
#define SQL_API_SQLGETSTMTOPTION 46
#define SQL_API_SQLGETTYPEINFO 47
#define SQL_API_SQLPARAMDATA 48
#define SQL_API_SQLPUTDATA 49
#define SQL_API_SQLSETCONNECTOPTION 50
#define SQL_API_SQLSETSTMTOPTION 51
#define SQL_API_SQLSPECIALCOLUMNS 52
#define SQL_API_SQLSTATISTICS 53
#define SQL_API_SQLTABLES 54
#define SQL_API_SQLDATASOURCES 57
#define SQL_API_SQLSETCONNECTATTR 1016
#define SQL_API_SQLSETSTMTATTR 1020
#define SQL_API_SQLBINDFILETOCOL 1250
#define SQL_API_SQLBINDFILETOPARAM 1251
#define SQL_API_SQLSETCOLATTRIBUTES 1252
#define SQL_API_SQLGETSQLCA 1253
#define SQL_API_SQLSETCONNECTION 1254
#define SQL_API_SQLGETDATALINKATTR 1255
#define SQL_API_SQLBUILDDATALINK 1256
#define SQL_API_SQLNEXTRESULT 1257
#define SQL_API_SQLEXTENDEDPREPARE 1296
#define SQL_API_SQLEXTENDEDBIND 1297
#define SQL_API_SQLFETCHSCROLL 1021
#define SQL_API_SQLGETLENGTH 1022
#define SQL_API_SQLGETPOSITION 1023
#define SQL_API_SQLGETSUBSTRING 1024
#define SQL_API_SQLALLOCHANDLE 1001
#define SQL_API_SQLFREEHANDLE 1006
#define SQL_API_SQLCLOSECURSOR 1003
#define SQL_API_SQLENDTRAN 1005
#define SQL_API_SQLCOLATTRIBUTE 6
#define SQL_API_SQLGETSTMTATTR 1014
#define SQL_API_SQLGETCONNECTATTR 1007
/* SQLGetFunction defines - unsupported functions */
#define SQL_EXT_API_LAST 72
/* Information requested by SQLGetInfo() */
#define SQL_MAX_DRIVER_CONNECTIONS 0
#define SQL_MAXIMUM_DRIVER_CONNECTIONS SQL_MAX_DRIVER_CONNECTIONS
#define SQL_MAX_CONCURRENT_ACTIVITIES 1
#define SQL_MAXIMUM_CONCURRENT_ACTIVITIES SQL_MAX_CONCURRENT_ACTIVITIES
#define SQL_ATTR_ANSI_APP 115
/*
* Defines for SQLGetDataLinkAttr.
*/
#define SQL_DATALINK_URL "URL"
/*
* Datalink attribute values for SQLGetDataLinkAttr.
*/
#define SQL_ATTR_DATALINK_COMMENT 1
#define SQL_ATTR_DATALINK_LINKTYPE 2
#define SQL_ATTR_DATALINK_URLCOMPLETE 3
#define SQL_ATTR_DATALINK_URLPATH 4
#define SQL_ATTR_DATALINK_URLPATHONLY 5
#define SQL_ATTR_DATALINK_URLSCHEME 6
#define SQL_ATTR_DATALINK_URLSERVER 7
/* SQLGetInfo defines - Info Type */
#define SQL_DATA_SOURCE_NAME 2
#define SQL_FETCH_DIRECTION 8
#define SQL_SERVER_NAME 13
#define SQL_SEARCH_PATTERN_ESCAPE 14
#define SQL_DBMS_NAME 17
#define SQL_DBMS_VER 18
#define SQL_ACCESSIBLE_TABLES 19
#define SQL_ACCESSIBLE_PROCEDURES 20
#define SQL_CURSOR_COMMIT_BEHAVIOR 23
#define SQL_DATA_SOURCE_READ_ONLY 25
#define SQL_DEFAULT_TXN_ISOLATION 26
#define SQL_IDENTIFIER_CASE 28
#define SQL_IDENTIFIER_QUOTE_CHAR 29
#define SQL_MAX_COLUMN_NAME_LEN 30
#define SQL_MAXIMUM_COLUMN_NAME_LENGTH SQL_MAX_COLUMN_NAME_LEN
#define SQL_MAX_CURSOR_NAME_LEN 31
#define SQL_MAXIMUM_CURSOR_NAME_LENGTH SQL_MAX_CURSOR_NAME_LEN
#define SQL_MAX_TABLE_NAME_LEN 35
#define SQL_SCROLL_CONCURRENCY 43
#define SQL_TXN_CAPABLE 46
#define SQL_TRANSACTION_CAPABLE SQL_TXN_CAPABLE
#define SQL_USER_NAME 47
#define SQL_TXN_ISOLATION_OPTION 72
#define SQL_TRANSACTION_ISOLATION_OPTION SQL_TXN_ISOLATION_OPTION
#define SQL_GETDATA_EXTENSIONS 81
#define SQL_NULL_COLLATION 85
#define SQL_ALTER_TABLE 86
#define SQL_ORDER_BY_COLUMNS_IN_SELECT 90
#define SQL_SPECIAL_CHARACTERS 94
#define SQL_MAX_COLUMNS_IN_GROUP_BY 97
#define SQL_MAXIMUM_COLUMNS_IN_GROUP_BY SQL_MAX_COLUMNS_IN_GROUP_BY
#define SQL_MAX_COLUMNS_IN_INDEX 98
#define SQL_MAXIMUM_COLUMNS_IN_INDEX SQL_MAX_COLUMNS_IN_INDEX
#define SQL_MAX_COLUMNS_IN_ORDER_BY 99
#define SQL_MAXIMUM_COLUMNS_IN_ORDER_BY SQL_MAX_COLUMNS_IN_ORDER_BY
#define SQL_MAX_COLUMNS_IN_SELECT 100
#define SQL_MAXIMUM_COLUMNS_IN_SELECT SQL_MAX_COLUMNS_IN_SELECT
#define SQL_MAX_COLUMNS_IN_TABLE 101
#define SQL_MAX_INDEX_SIZE 102
#define SQL_MAXIMUM_INDEX_SIZE SQL_MAX_INDEX_SIZE
#define SQL_MAX_ROW_SIZE 104
#define SQL_MAXIMUM_ROW_SIZE SQL_MAX_ROW_SIZE
#define SQL_MAX_STATEMENT_LEN 105
#define SQL_MAXIMUM_STATEMENT_LENGTH SQL_MAX_STATEMENT_LEN
#define SQL_MAX_TABLES_IN_SELECT 106
#define SQL_MAXIMUM_TABLES_IN_SELECT SQL_MAX_TABLES_IN_SELECT
#define SQL_MAX_USER_NAME_LEN 107
#define SQL_MAXIMUM_USER_NAME_LENGTH SQL_MAX_USER_NAME_LEN
#define SQL_MAX_SCHEMA_NAME_LEN SQL_MAX_OWNER_NAME_LEN
#define SQL_MAXIMUM_SCHEMA_NAME_LENGTH SQL_MAX_SCHEMA_NAME_LEN
#define SQL_MAX_CATALOG_NAME_LEN SQL_MAX_QUALIFIER_NAME_LEN
#define SQL_MAXIMUM_CATALOG_NAME_LENGTH SQL_MAX_CATALOG_NAME_LEN
#define SQL_OJ_CAPABILITIES 115
#define SQL_OUTER_JOIN_CAPABILITIES SQL_OJ_CAPABILITIES
#define SQL_XOPEN_CLI_YEAR 10000
#define SQL_CURSOR_SENSITIVITY 10001
#define SQL_DESCRIBE_PARAMETER 10002
#define SQL_CATALOG_NAME 10003
#define SQL_COLLATION_SEQ 10004
#define SQL_MAX_IDENTIFIER_LEN 10005
#define SQL_MAXIMUM_IDENTIFIER_LENGTH SQL_MAX_IDENTIFIER_LEN
#define SQL_INTEGRITY 73
#define SQL_DATABASE_CODEPAGE 2519
#define SQL_APPLICATION_CODEPAGE 2520
#define SQL_CONNECT_CODEPAGE 2521
#define SQL_ATTR_DB2_APPLICATION_ID 2532
#define SQL_ATTR_DB2_APPLICATION_HANDLE 2533
#define SQL_ATTR_HANDLE_XA_ASSOCIATED 2535
#define SQL_DB2_DRIVER_VER 2550
#define SQL_ATTR_XML_DECLARATION 2552
#define SQL_ATTR_CURRENT_IMPLICIT_XMLPARSE_OPTION 2553
#define SQL_ATTR_XQUERY_STATEMENT 2557
#define SQL_DB2_DRIVER_TYPE 2567
#define SQL_INFO_LAST 114
#define SQL_INFO_DRIVER_START 1000
/*
* SQLExtendedPrepare statement types.
*/
#define SQL_CLI_STMT_UNDEFINED 0
#define SQL_CLI_STMT_ALTER_TABLE 1
#define SQL_CLI_STMT_CREATE_INDEX 5
#define SQL_CLI_STMT_CREATE_TABLE 6
#define SQL_CLI_STMT_CREATE_VIEW 7
#define SQL_CLI_STMT_DELETE_SEARCHED 8
#define SQL_CLI_STMT_DELETE_POSITIONED 9
#define SQL_CLI_STMT_DROP_PACKAGE 10
#define SQL_CLI_STMT_DROP_INDEX 11
#define SQL_CLI_STMT_DROP_TABLE 12
#define SQL_CLI_STMT_DROP_VIEW 13
#define SQL_CLI_STMT_GRANT 14
#define SQL_CLI_STMT_INSERT 15
#define SQL_CLI_STMT_REVOKE 16
#define SQL_CLI_STMT_SELECT 18
#define SQL_CLI_STMT_UPDATE_SEARCHED 19
#define SQL_CLI_STMT_UPDATE_POSITIONED 20
#define SQL_CLI_STMT_CALL 24
#define SQL_CLI_STMT_SELECT_FOR_UPDATE 29
#define SQL_CLI_STMT_WITH 30
#define SQL_CLI_STMT_SELECT_FOR_FETCH 31
#define SQL_CLI_STMT_VALUES 32
#define SQL_CLI_STMT_CREATE_TRIGGER 34
#define SQL_CLI_STMT_SELECT_OPTIMIZE_FOR_NROWS 39
#define SQL_CLI_STMT_SELECT_INTO 40
#define SQL_CLI_STMT_CREATE_PROCEDURE 41
#define SQL_CLI_STMT_CREATE_FUNCTION 42
#define SQL_CLI_STMT_INSERT_VALUES 45
#define SQL_CLI_STMT_SET_CURRENT_QUERY_OPT 46
#define SQL_CLI_STMT_MERGE 56
#define SQL_CLI_STMT_XQUERY 59
/*
* IBM specific SQLGetInfo values.
*/
#define SQL_IBM_ALTERTABLEVARCHAR 1000
/* SQL_ALTER_TABLE bitmasks */
#define SQL_AT_ADD_COLUMN 0x00000001L
#define SQL_AT_DROP_COLUMN 0x00000002L
#define SQL_AT_ADD_CONSTRAINT 0x00000008L
/* SQL_CURSOR_COMMIT_BEHAVIOR and SQL_CURSOR_ROLLBACK_BEHAVIOR values */
#define SQL_CB_DELETE 0x0000
#define SQL_CB_CLOSE 0x0001
#define SQL_CB_PRESERVE 0x0002
/* SQL_IDENTIFIER_CASE values */
#define SQL_IC_UPPER 0x0001
#define SQL_IC_LOWER 0x0002
#define SQL_IC_SENSITIVE 0x0003
#define SQL_IC_MIXED 0x0004
/* SQL_TXN_CAPABLE values */
#define SQL_TC_NONE 0x0000
#define SQL_TC_DML 0x0001
#define SQL_TC_ALL 0x0002
#define SQL_TC_DDL_COMMIT 0x0003
#define SQL_TC_DDL_IGNORE 0x0004
/* SQL_SCROLL_CONCURRENCY masks */
#define SQL_SCCO_READ_ONLY 0x00000001L
#define SQL_SCCO_LOCK 0x00000002L
#define SQL_SCCO_OPT_ROWVER 0x00000004L
#define SQL_SCCO_OPT_VALUES 0x00000008L
/* SQL_FETCH_DIRECTION masks */
#define SQL_FD_FETCH_NEXT 0x00000001L
#define SQL_FD_FETCH_FIRST 0x00000002L
#define SQL_FD_FETCH_LAST 0x00000004L
#define SQL_FD_FETCH_PRIOR 0x00000008L
#define SQL_FD_FETCH_ABSOLUTE 0x00000010L
#define SQL_FD_FETCH_RELATIVE 0x00000020L
#define SQL_FD_FETCH_RESUME 0x00000040L
/* SQL_TXN_ISOLATION_OPTION masks */
#define SQL_TXN_READ_UNCOMMITTED 0x00000001L
#define SQL_TRANSACTION_READ_UNCOMMITTED SQL_TXN_READ_UNCOMMITTED
#define SQL_TXN_READ_COMMITTED 0x00000002L
#define SQL_TRANSACTION_READ_COMMITTED SQL_TXN_READ_COMMITTED
#define SQL_TXN_REPEATABLE_READ 0x00000004L
#define SQL_TRANSACTION_REPEATABLE_READ SQL_TXN_REPEATABLE_READ
#define SQL_TXN_SERIALIZABLE 0x00000008L
#define SQL_TRANSACTION_SERIALIZABLE SQL_TXN_SERIALIZABLE
#define SQL_TXN_NOCOMMIT 0x00000020L
#define SQL_TRANSACTION_NOCOMMIT SQL_TXN_NOCOMMIT
/* SQL_GETDATA_EXTENSIONS values */
#define SQL_GD_ANY_COLUMN 0x00000001L
#define SQL_GD_ANY_ORDER 0x00000002L
/* SQL_OJ_CAPABILITIES values */
#define SQL_OJ_LEFT 0x00000001L
#define SQL_OJ_RIGHT 0x00000002L
#define SQL_OJ_FULL 0x00000004L
#define SQL_OJ_NESTED 0x00000008L
#define SQL_OJ_NOT_ORDERED 0x00000010L
#define SQL_OJ_INNER 0x00000020L
#define SQL_OJ_ALL_COMPARISON_OPS 0x00000040L
/* SQL_DB2_DRIVER_TYPE values */
#define SQL_CLI_DRIVER_TYPE_UNDEFINED 0
#define SQL_CLI_DRIVER_RUNTIME_CLIENT 1
#define SQL_CLI_DRIVER_CLI_DRIVER 2
/* SQLGetTypeInfo define */
#define SQL_ALL_TYPES 0
/* Options for SQLGetStmtOption/SQLSetStmtOption */
#define SQL_ATTR_AUTO_IPD 10001
#define SQL_ATTR_APP_ROW_DESC 10010
#define SQL_ATTR_APP_PARAM_DESC 10011
#define SQL_ATTR_IMP_ROW_DESC 10012
#define SQL_ATTR_IMP_PARAM_DESC 10013
#define SQL_ATTR_METADATA_ID 10014
#define SQL_ATTR_CURSOR_SCROLLABLE (-1)
#define SQL_ATTR_CURSOR_SENSITIVITY (-2)
/* SQL_ATTR_CURSOR_SCROLLABLE values */
#define SQL_NONSCROLLABLE 0
#define SQL_SCROLLABLE 1
/* Options for SQLGetStmtOption/SQLSetStmtOption extensions */
#define SQL_CURSOR_HOLD 1250
#define SQL_ATTR_CURSOR_HOLD 1250
#define SQL_NODESCRIBE_OUTPUT 1251
#define SQL_ATTR_NODESCRIBE_OUTPUT 1251
#define SQL_NODESCRIBE_INPUT 1264
#define SQL_ATTR_NODESCRIBE_INPUT 1264
#define SQL_NODESCRIBE SQL_NODESCRIBE_OUTPUT
#define SQL_ATTR_NODESCRIBE SQL_NODESCRIBE_OUTPUT
#define SQL_CLOSE_BEHAVIOR 1257
#define SQL_ATTR_CLOSE_BEHAVIOR 1257
#define SQL_ATTR_CLOSE_BEHAVIOR 1257
#define SQL_ATTR_CLOSEOPEN 1265
#define SQL_ATTR_CURRENT_PACKAGE_SET 1276
#define SQL_ATTR_DEFERRED_PREPARE 1277
#define SQL_ATTR_EARLYCLOSE 1268
#define SQL_ATTR_PROCESSCTL 1278
#define SQL_ATTR_PREFETCH 1285
#define SQL_ATTR_ENABLE_IPD_SETTING 1286
/*
* Descriptor value for setting the descriptor type.
*/
#define SQL_DESC_DESCRIPTOR_TYPE 1287
#define SQL_ATTR_OPTIMIZE_SQLCOLUMNS 1288
#define SQL_ATTR_MEM_DEBUG_DUMP 1289
#define SQL_ATTR_CONNECT_NODE 1290
#define SQL_ATTR_CONNECT_WITH_XA 1291
#define SQL_ATTR_GET_XA_RESOURCE 1292
#define SQL_ATTR_DB2_SQLERRP 2451
#define SQL_ATTR_SERVER_MSGTXT_SP 2452
#define SQL_ATTR_OPTIMIZE_FOR_NROWS 2450
#define SQL_ATTR_QUERY_OPTIMIZATION_LEVEL 1293
#define SQL_ATTR_USE_LIGHT_OUTPUT_SQLDA 1298
#define SQL_ATTR_CURSOR_BLOCK_NUM_ROWS 2453
#define SQL_ATTR_CURSOR_BLOCK_EARLY_CLOSE 2454
#define SQL_ATTR_SERVER_MSGTXT_MASK 2455
#define SQL_ATTR_USE_LIGHT_INPUT_SQLDA 2458
#define SQL_ATTR_BLOCK_FOR_NROWS 2459
#define SQL_ATTR_OPTIMIZE_ROWS_FOR_BLOCKING 2460
#define SQL_ATTR_STATICMODE 2467
#define SQL_ATTR_DB2_MESSAGE_PREFIX 2468
#define SQL_ATTR_CALL_RETVAL_AS_PARM 2469
#define SQL_ATTR_CALL_RETURN 2470
#define SQL_ATTR_RETURN_USER_DEFINED_TYPES 2471
#define SQL_ATTR_ENABLE_EXTENDED_PARAMDATA 2472
#define SQL_ATTR_APP_TYPE 2473
#define SQL_ATTR_TRANSFORM_GROUP 2474
#define SQL_ATTR_DESCRIBE_CALL 2476
#define SQL_ATTR_AUTOCOMMCLEANUP 2477
#define SQL_ATTR_USEMALLOC 2478
#define SQL_ATTR_PRESERVE_LOCALE 2479
#define SQL_ATTR_MAPGRAPHIC 2480
#define SQL_ATTR_INSERT_BUFFERING 2481
#define SQL_ATTR_USE_LOAD_API 2482
#define SQL_ATTR_LOAD_RECOVERABLE 2483
#define SQL_ATTR_LOAD_COPY_LOCATION 2484
#define SQL_ATTR_LOAD_MESSAGE_FILE 2485
#define SQL_ATTR_LOAD_SAVECOUNT 2486
#define SQL_ATTR_LOAD_CPU_PARALLELISM 2487
#define SQL_ATTR_LOAD_DISK_PARALLELISM 2488
#define SQL_ATTR_LOAD_INDEXING_MODE 2489
#define SQL_ATTR_LOAD_STATS_MODE 2490
#define SQL_ATTR_LOAD_TEMP_FILES_PATH 2491
#define SQL_ATTR_LOAD_DATA_BUFFER_SIZE 2492
#define SQL_ATTR_LOAD_MODIFIED_BY 2493
#define SQL_ATTR_DB2_RESERVED_2494 2494
#define SQL_ATTR_DESCRIBE_BEHAVIOR 2495
#define SQL_ATTR_FETCH_SENSITIVITY 2496
#define SQL_ATTR_DB2_RESERVED_2497 2497
#define SQL_ATTR_CLIENT_LOB_BUFFERING 2498
#define SQL_ATTR_SKIP_TRACE 2499
#define SQL_ATTR_LOAD_INFO 2501
#define SQL_ATTR_DESCRIBE_INPUT_ON_PREPARE 2505
#define SQL_ATTR_DESCRIBE_OUTPUT_LEVEL 2506
#define SQL_ATTR_CURRENT_PACKAGE_PATH 2509
#define SQL_ATTR_INFO_PROGRAMID 2511
#define SQL_ATTR_INFO_PROGRAMNAME 2516
#define SQL_ATTR_FREE_LOCATORS_ON_FETCH 2518
#define SQL_ATTR_KEEP_DYNAMIC 2522
#define SQL_ATTR_LOAD_ROWS_READ_PTR 2524
#define SQL_ATTR_LOAD_ROWS_SKIPPED_PTR 2525
#define SQL_ATTR_LOAD_ROWS_COMMITTED_PTR 2526
#define SQL_ATTR_LOAD_ROWS_LOADED_PTR 2527
#define SQL_ATTR_LOAD_ROWS_REJECTED_PTR 2528
#define SQL_ATTR_LOAD_ROWS_DELETED_PTR 2529
#define SQL_ATTR_LOAD_INFO_VER 2530
#define SQL_ATTR_SET_SSA 2531
#define SQL_ATTR_BLOCK_LOBS 2534
#define SQL_ATTR_LOAD_ACCESS_LEVEL 2536
#define SQL_ATTR_MAPCHAR 2546
#define SQL_ATTR_ARM_CORRELATOR 2554
#define SQL_ATTR_CLIENT_DEBUGINFO 2556
/*
* SQL_ATTR_DESCRIBE_INPUT / SQL_ATTR_DESCRIBE_OUTPUT values
*/
#define SQL_DESCRIBE_NONE 0
#define SQL_DESCRIBE_LIGHT 1
#define SQL_DESCRIBE_REGULAR 2
#define SQL_DESCRIBE_EXTENDED 3
/*
* Use load values.
*/
#define SQL_USE_LOAD_OFF 0
#define SQL_USE_LOAD_INSERT 1
#define SQL_USE_LOAD_REPLACE 2
#define SQL_USE_LOAD_RESTART 3
#define SQL_USE_LOAD_TERMINATE 4
/*
* SQL_ATTR_PREFETCH_ENABLE values.
*/
#define SQL_PREFETCH_ON 1
#define SQL_PREFETCH_OFF 0
#define SQL_PREFETCH_DEFAULT SQL_PREFETCH_OFF
/* SQL_CLOSE_BEHAVIOR values. */
#define SQL_CC_NO_RELEASE 0
#define SQL_CC_RELEASE 1
#define SQL_CC_DEFAULT SQL_CC_NO_RELEASE
/* SQL_ATTR_DEFERRED_PREPARE values */
#define SQL_DEFERRED_PREPARE_ON 1
#define SQL_DEFERRED_PREPARE_OFF 0
#define SQL_DEFERRED_PREPARE_DEFAULT SQL_DEFERRED_PREPARE_ON
/* SQL_ATTR_EARLYCLOSE values */
#define SQL_EARLYCLOSE_ON 1
#define SQL_EARLYCLOSE_OFF 0
#define SQL_EARLYCLOSE_SERVER 2
#define SQL_EARLYCLOSE_DEFAULT SQL_EARLYCLOSE_ON
/* SQL_ATTR_APP_TYPE values */
#define SQL_APP_TYPE_ODBC 1
#define SQL_APP_TYPE_OLEDB 2
#define SQL_APP_TYPE_JDBC 3
#define SQL_APP_TYPE_ADONET 4
#define SQL_APP_TYPE_DEFAULT SQL_APP_TYPE_ODBC
/* SQL_ATTR_PROCESSCTL masks */
#define SQL_PROCESSCTL_NOTHREAD 0x00000001L
#define SQL_PROCESSCTL_NOFORK 0x00000002L
#define SQL_PROCESSCTL_SHARESTMTDESC 0x00000004L
/* CLI attribute/option values */
#define SQL_FALSE 0
#define SQL_TRUE 1
/* Options for SQL_CURSOR_HOLD */
#define SQL_CURSOR_HOLD_ON 1
#define SQL_CURSOR_HOLD_OFF 0
#define SQL_CURSOR_HOLD_DEFAULT SQL_CURSOR_HOLD_ON
/* Options for SQL_NODESCRIBE_INPUT/SQL_NODESCRIBE_OUTPUT */
#define SQL_NODESCRIBE_ON 1
#define SQL_NODESCRIBE_OFF 0
#define SQL_NODESCRIBE_DEFAULT SQL_NODESCRIBE_OFF
/* Options for SQL_ATTR_DESCRIBE_CALL */
#define SQL_DESCRIBE_CALL_NEVER 0
#define SQL_DESCRIBE_CALL_BEFORE 1
#define SQL_DESCRIBE_CALL_ON_ERROR 2
#define SQL_DESCRIBE_CALL_DEFAULT (-1)
/* Options for SQL_ATTR_CLIENT_LOB_BUFFERING */
#define SQL_CLIENTLOB_USE_LOCATORS 0
#define SQL_CLIENTLOB_BUFFER_UNBOUND_LOBS 1
#define SQL_CLIENTLOB_DEFAULT SQL_CLIENTLOB_USE_LOCATORS
/* Options for SQL_ATTR_PREPDESC_BEHAVIOR */
/* To be determined */
/* Options for SQLGetConnectOption/SQLSetConnectOption extensions */
#define SQL_WCHARTYPE 1252
#define SQL_LONGDATA_COMPAT 1253
#define SQL_CURRENT_SCHEMA 1254
#define SQL_DB2EXPLAIN 1258
#define SQL_DB2ESTIMATE 1259
#define SQL_PARAMOPT_ATOMIC 1260
#define SQL_STMTTXN_ISOLATION 1261
#define SQL_MAXCONN 1262
#define SQL_ATTR_CLISCHEMA 1280
#define SQL_ATTR_INFO_USERID 1281
#define SQL_ATTR_INFO_WRKSTNNAME 1282
#define SQL_ATTR_INFO_APPLNAME 1283
#define SQL_ATTR_INFO_ACCTSTR 1284
#define SQL_ATTR_AUTOCOMMIT_NOCOMMIT 2462
#define SQL_ATTR_QUERY_PATROLLER 2466
#define SQL_ATTR_CHAINING_BEGIN 2464
#define SQL_ATTR_CHAINING_END 2465
#define SQL_ATTR_EXTENDEDBIND 2475
#define SQL_ATTR_GRAPHIC_UNICODESERVER 2503
#define SQL_ATTR_RETURN_CHAR_AS_WCHAR_OLEDB 2517
#define SQL_ATTR_GATEWAY_CONNECTED 2537
#define SQL_ATTR_SQLCOLUMNS_SORT_BY_ORDINAL_OLEDB 2542
#define SQL_ATTR_REPORT_ISLONG_FOR_LONGTYPES_OLEDB 2543
#define SQL_ATTR_PING_DB 2545
#define SQL_ATTR_RECEIVE_TIMEOUT 2547
#define SQL_ATTR_REOPT 2548
#define SQL_ATTR_LOB_CACHE_SIZE 2555
#define SQL_ATTR_STREAM_GETDATA 2558
#define SQL_ATTR_APP_USES_LOB_LOCATOR 2559
#define SQL_ATTR_MAX_LOB_BLOCK_SIZE 2560
#define SQL_ATTR_USE_TRUSTED_CONTEXT 2561
#define SQL_ATTR_TRUSTED_CONTEXT_USERID 2562
#define SQL_ATTR_TRUSTED_CONTEXT_PASSWORD 2563
#define SQL_ATTR_USER_REGISTRY_NAME 2564
#define SQL_ATTR_DECFLOAT_ROUNDING_MODE 2565
#define SQL_ATTR_APPEND_FOR_FETCH_ONLY 2573
#define SQL_ATTR_ONLY_USE_BIG_PACKAGES 2577
#define SQL_ATTR_WCHARTYPE SQL_WCHARTYPE
#define SQL_ATTR_LONGDATA_COMPAT SQL_LONGDATA_COMPAT
#define SQL_ATTR_CURRENT_SCHEMA SQL_CURRENT_SCHEMA
#define SQL_ATTR_DB2EXPLAIN SQL_DB2EXPLAIN
#define SQL_ATTR_DB2ESTIMATE SQL_DB2ESTIMATE
#define SQL_ATTR_PARAMOPT_ATOMIC SQL_PARAMOPT_ATOMIC
#define SQL_ATTR_STMTTXN_ISOLATION SQL_STMTTXN_ISOLATION
#define SQL_ATTR_MAXCONN SQL_MAXCONN
/* Options for SQLSetConnectOption, SQLSetEnvAttr */
#define SQL_CONNECTTYPE 1255
#define SQL_SYNC_POINT 1256
#define SQL_MINMEMORY_USAGE 1263
#define SQL_CONN_CONTEXT 1269
#define SQL_ATTR_INHERIT_NULL_CONNECT 1270
#define SQL_ATTR_FORCE_CONVERSION_ON_CLIENT 1275
#define SQL_ATTR_INFO_KEYWORDLIST 2500
#define SQL_ATTR_CONNECTTYPE SQL_CONNECTTYPE
#define SQL_ATTR_SYNC_POINT SQL_SYNC_POINT
#define SQL_ATTR_MINMEMORY_USAGE SQL_MINMEMORY_USAGE
#define SQL_ATTR_CONN_CONTEXT SQL_CONN_CONTEXT
/* Options for SQL_LONGDATA_COMPAT */
#define SQL_LD_COMPAT_YES 1
#define SQL_LD_COMPAT_NO 0
#define SQL_LD_COMPAT_DEFAULT SQL_LD_COMPAT_NO
/* Options for SQL_ATTR_EXTENDEDBIND */
#define SQL_ATTR_EXTENDEDBIND_COPY 1
#define SQL_ATTR_EXTENDEDBIND_NOCOPY 0
#define SQL_ATTR_EXTENDEDBIND_DEFAULT SQL_ATTR_EXTENDEDBIND_NOCOPY
/* SQL_NULL_COLLATION values */
#define SQL_NC_HIGH 0
#define SQL_NC_LOW 1
/* Options for SQLGetInfo extentions */
#define CLI_MAX_LONGVARCHAR 1250
#define CLI_MAX_VARCHAR 1251
#define CLI_MAX_CHAR 1252
#define CLI_MAX_LONGVARGRAPHIC 1253
#define CLI_MAX_VARGRAPHIC 1254
#define CLI_MAX_GRAPHIC 1255
/*
* Private SQLGetDiagField extensions.
*/
#define SQL_DIAG_MESSAGE_TEXT_PTR 2456
#define SQL_DIAG_LINE_NUMBER 2461
#define SQL_DIAG_ERRMC 2467
#define SQL_DIAG_BYTES_PROCESSED 2477
#define SQL_DIAG_RELATIVE_COST_ESTIMATE 2504
#define SQL_DIAG_ROW_COUNT_ESTIMATE 2507
#define SQL_DIAG_ELAPSED_SERVER_TIME 2538
#define SQL_DIAG_ELAPSED_NETWORK_TIME 2539
#define SQL_DIAG_ACCUMULATED_SERVER_TIME 2540
#define SQL_DIAG_ACCUMULATED_NETWORK_TIME 2541
#define SQL_DIAG_QUIESCE 2549
#define SQL_DIAG_TOLERATED_ERROR 2559
/*
* Values for SQL_DIAG_QUIESCE
*/
#define SQL_DIAG_QUIESCE_NO 0
#define SQL_DIAG_QUIESCE_DATABASE 1
#define SQL_DIAG_QUIESCE_INSTANCE 2
/*
* Private SQLSetEnvAttr extensions.
*/
#define SQL_ATTR_LITTLE_ENDIAN_UNICODE 2457
#define SQL_ATTR_DIAGLEVEL 2574
#define SQL_ATTR_NOTIFYLEVEL 2575
#define SQL_ATTR_DIAGPATH 2576
/*
* Options for SQL_PARAMOPT_ATOMIC
*/
#define SQL_ATOMIC_YES 1
#define SQL_ATOMIC_NO 0
#define SQL_ATOMIC_DEFAULT SQL_ATOMIC_YES
/* Options for SQL_CONNECT_TYPE */
#define SQL_CONCURRENT_TRANS 1
#define SQL_COORDINATED_TRANS 2
#define SQL_CONNECTTYPE_DEFAULT SQL_CONCURRENT_TRANS
/* Options for SQL_SYNCPOINT */
#define SQL_ONEPHASE 1
#define SQL_TWOPHASE 2
#define SQL_SYNCPOINT_DEFAULT SQL_ONEPHASE
/* Options for SQL_DB2ESTIMATE */
#define SQL_DB2ESTIMATE_ON 1
#define SQL_DB2ESTIMATE_OFF 0
#define SQL_DB2ESTIMATE_DEFAULT SQL_DB2ESTIMATE_OFF
/* Options for SQL_DB2EXPLAIN */
#define SQL_DB2EXPLAIN_OFF 0x00000000L
#define SQL_DB2EXPLAIN_SNAPSHOT_ON 0x00000001L
#define SQL_DB2EXPLAIN_MODE_ON 0x00000002L
#define SQL_DB2EXPLAIN_SNAPSHOT_MODE_ON SQL_DB2EXPLAIN_SNAPSHOT_ON+SQL_DB2EXPLAIN_MODE_ON
#define SQL_DB2EXPLAIN_ON SQL_DB2EXPLAIN_SNAPSHOT_ON
#define SQL_DB2EXPLAIN_DEFAULT SQL_DB2EXPLAIN_OFF
/* Options for SQL_WCHARTYPE
* Note that you can only specify SQL_WCHARTYPE_CONVERT if you have an
* external compile flag SQL_WCHART_CONVERT defined
*/
#ifdef SQL_WCHART_CONVERT
#define SQL_WCHARTYPE_CONVERT 1
#endif
#define SQL_WCHARTYPE_NOCONVERT 0
#define SQL_WCHARTYPE_DEFAULT SQL_WCHARTYPE_NOCONVERT
/* Options for SQL_ATTR_OPTIMIZE_SQLCOLUMNS
*
*/
#define SQL_OPTIMIZE_SQLCOLUMNS_OFF 0
#define SQL_OPTIMIZE_SQLCOLUMNS_ON 1
#define SQL_OPTIMIZE_SQLCOLUMNS_DEFAULT SQL_OPTIMIZE_SQLCOLUMNS_OFF
/* Options for SQL_ATTR_CONNECT_WITH_XA
*
*/
#define SQL_CONNECT_WITH_XA_OFF 0
#define SQL_CONNECT_WITH_XA_ON 1
#define SQL_CONNECT_WITH_XA_DEFAULT SQL_CONNECT_WITH_XA_OFF
/*
* Options for SQL_ATTR_SERVER_MSGTXT_MASK
*/
#define SQL_ATTR_SERVER_MSGTXT_MASK_LOCAL_FIRST 0x00000000
#define SQL_ATTR_SERVER_MSGTXT_MASK_WARNINGS 0x00000001
#define SQL_ATTR_SERVER_MSGTXT_MASK_ERRORS 0xFFFFFFFE
#define SQL_ATTR_SERVER_MSGTXT_MASK_ALL 0xFFFFFFFF
#define SQL_ATTR_SERVER_MSGTXT_MASK_DEFAULT SQL_ATTR_SERVER_MSGTXT_MASK_LOCAL_FIRST
/*
* Options for SQL_ATTR_QUERY_PATROLLER
*/
#define SQL_ATTR_QUERY_PATROLLER_DISABLE 1
#define SQL_ATTR_QUERY_PATROLLER_ENABLE 2
#define SQL_ATTR_QUERY_PATROLLER_BYPASS 3
/*
* Options for SQL_ATTR_STATICMODE
*/
#define SQL_STATICMODE_DISABLED 0
#define SQL_STATICMODE_CAPTURE 1
#define SQL_STATICMODE_MATCH 2
/*
* Options for SQL_ATTR_DB2_MESSAGE_PREFIX
*/
#define SQL_ATTR_DB2_MESSAGE_PREFIX_OFF 0
#define SQL_ATTR_DB2_MESSAGE_PREFIX_ON 1
#define SQL_ATTR_DB2_MESSAGE_PREFIX_DEFAULT SQL_ATTR_DB2_MESSAGE_PREFIX_ON
/*
* Options for SQL_ATTR_INSERT_BUFFERING
*/
#define SQL_ATTR_INSERT_BUFFERING_OFF 0
#define SQL_ATTR_INSERT_BUFFERING_ON 1
#define SQL_ATTR_INSERT_BUFFERING_IGD 2
/* Column types and scopes in SQLSpecialColumns */
#define SQL_SCOPE_CURROW 0
#define SQL_SCOPE_TRANSACTION 1
#define SQL_SCOPE_SESSION 2
/* Defines for SQLStatistics */
#define SQL_INDEX_UNIQUE 0
#define SQL_INDEX_ALL 1
/* Defines for SQLStatistics (returned in the result set) */
#define SQL_INDEX_CLUSTERED 1
#define SQL_INDEX_HASHED 2
#define SQL_INDEX_OTHER 3
/* Defines for SQLSpecialColumns (returned in the result set) */
#define SQL_PC_UNKNOWN 0
#define SQL_PC_NON_PSEUDO 1
#define SQL_PC_PSEUDO 2
/* Reserved value for the IdentifierType argument of SQLSpecialColumns() */
#define SQL_ROW_IDENTIFIER 1
/* Options for SQL_ATTR_MAPGRAPHIC */
#define SQL_MAPGRAPHIC_DEFAULT -1
#define SQL_MAPGRAPHIC_GRAPHIC 0
#define SQL_MAPGRAPHIC_WCHAR 1
/* Options for SQL_ATTR_MAPCHAR */
#define SQL_MAPCHAR_DEFAULT 0
#define SQL_MAPCHAR_WCHAR 1
/* SQLDataSources "fDirection" values, also used on SQLExtendedFetch() */
/* See sqlext.h for additional SQLExtendedFetch fetch direction defines */
#define SQL_FETCH_NEXT 1
#define SQL_FETCH_FIRST 2
/* OTHER CODES USED FOR FETCHORIENTATION IN SQLFETCHSCROLL() */
#define SQL_FETCH_LAST 3
#define SQL_FETCH_PRIOR 4
#define SQL_FETCH_ABSOLUTE 5
#define SQL_FETCH_RELATIVE 6
/* SQL_ATTR_XML_DECLARATION bitmask values */
#define SQL_XML_DECLARATION_NONE 0x00000000
#define SQL_XML_DECLARATION_BOM 0x00000001
#define SQL_XML_DECLARATION_BASE 0x00000002
#define SQL_XML_DECLARATION_ENCATTR 0x00000004
/*
* Environment attributes; note SQL_CONNECTTYPE, SQL_SYNC_POINT are also
* environment attributes that are settable at the connection level
*/
#define SQL_ATTR_OUTPUT_NTS 10001
/* LOB file reference options */
#ifndef SQL_H_SQL /* if sql.h is not included, then... */
#define SQL_FILE_READ 2 /* Input file to read from */
#define SQL_FILE_CREATE 8 /* Output file - new file to be */
/* created */
#define SQL_FILE_OVERWRITE 16 /* Output file - overwrite existing */
/* file or create a new file if it */
/* doesn't exist */
#define SQL_FILE_APPEND 32 /* Output file - append to an */
/* existing file or create a new file */
/* if it doesn't exist */
#endif
/*
* Source of string for SQLGetLength(), SQLGetPosition(),
* and SQLGetSubstring().
*/
#define SQL_FROM_LOCATOR 2
#define SQL_FROM_LITERAL 3
/*
* Options for Rounding Modes. These numeric values can
* be set with SQLSetConnectAttr() API for the attribute
* SQL_ATTR_DECFLOAT_ROUNDING_MODE. The SQLGetConnectAttr()
* API will return these values for the
* SQL_ATTR_DECFLOAT_ROUNDING_MODE attribute.
*/
#define SQL_ROUND_HALF_EVEN 0
#define SQL_ROUND_HALF_UP 1
#define SQL_ROUND_DOWN 2
#define SQL_ROUND_CEILING 3
#define SQL_ROUND_FLOOR 4
#define SQL_ROUND_HALF_DOWN 5
#define SQL_ROUND_UP 6
/*
* Function definitions of APIs in both X/Open CLI and ODBC
*/
SQLRETURN SQL_API_FN SQLColumns (SQLHSTMT hstmt,
SQLCHAR FAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLCHAR FAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLCHAR FAR *szTableName,
SQLSMALLINT cbTableName,
SQLCHAR FAR *szColumnName,
SQLSMALLINT cbColumnName);
SQLRETURN SQL_API_FN SQLDataSources (SQLHENV henv,
SQLUSMALLINT fDirection,
SQLCHAR FAR *szDSN,
SQLSMALLINT cbDSNMax,
SQLSMALLINT FAR *pcbDSN,
SQLCHAR FAR *szDescription,
SQLSMALLINT cbDescriptionMax,
SQLSMALLINT FAR *pcbDescription);
SQLRETURN SQL_API SQLFetchScroll( SQLHSTMT StatementHandle,
SQLSMALLINT FetchOrientation,
SQLLEN FetchOffset);
SQLRETURN SQL_API SQLGetConnectAttr( SQLHDBC ConnectionHandle,
SQLINTEGER Attribute,
SQLPOINTER Value,
SQLINTEGER BufferLength,
SQLINTEGER *StringLength);
SQLRETURN SQL_API_FN SQLGetConnectOption (
SQLHDBC hdbc,
SQLUSMALLINT fOption,
SQLPOINTER pvParam);
SQLRETURN SQL_API_FN SQLGetFunctions (SQLHDBC hdbc,
SQLUSMALLINT fFunction,
SQLUSMALLINT FAR *pfExists);
SQLRETURN SQL_API_FN SQLGetInfo (SQLHDBC hdbc,
SQLUSMALLINT fInfoType,
SQLPOINTER rgbInfoValue,
SQLSMALLINT cbInfoValueMax,
SQLSMALLINT FAR *pcbInfoValue);
SQLRETURN SQL_API SQLGetStmtAttr( SQLHSTMT StatementHandle,
SQLINTEGER Attribute,
SQLPOINTER Value,
SQLINTEGER BufferLength,
SQLINTEGER *StringLength);
SQLRETURN SQL_API_FN SQLGetStmtOption (SQLHSTMT hstmt,
SQLUSMALLINT fOption,
SQLPOINTER pvParam);
SQLRETURN SQL_API_FN SQLGetTypeInfo (SQLHSTMT hstmt,
SQLSMALLINT fSqlType);
SQLRETURN SQL_API_FN SQLParamData (SQLHSTMT hstmt,
SQLPOINTER FAR *prgbValue);
SQLRETURN SQL_API_FN SQLPutData (SQLHSTMT hstmt,
SQLPOINTER rgbValue,
SQLLEN cbValue);
SQLRETURN SQL_API_FN SQLSetConnectAttr(
SQLHDBC hdbc,
SQLINTEGER fOption,
SQLPOINTER pvParam,
SQLINTEGER fStrLen);
SQLRETURN SQL_API_FN SQLSetConnectOption(
SQLHDBC hdbc,
SQLUSMALLINT fOption,
SQLULEN vParam);
SQLRETURN SQL_API_FN SQLSetStmtAttr (SQLHSTMT hstmt,
SQLINTEGER fOption,
SQLPOINTER pvParam,
SQLINTEGER fStrLen);
SQLRETURN SQL_API_FN SQLSetStmtOption (SQLHSTMT hstmt,
SQLUSMALLINT fOption,
SQLULEN vParam);
SQLRETURN SQL_API_FN SQLSpecialColumns(SQLHSTMT hstmt,
SQLUSMALLINT fColType,
SQLCHAR FAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLCHAR FAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLCHAR FAR *szTableName,
SQLSMALLINT cbTableName,
SQLUSMALLINT fScope,
SQLUSMALLINT fNullable);
SQLRETURN SQL_API_FN SQLStatistics (SQLHSTMT hstmt,
SQLCHAR FAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLCHAR FAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLCHAR FAR *szTableName,
SQLSMALLINT cbTableName,
SQLUSMALLINT fUnique,
SQLUSMALLINT fAccuracy);
SQLRETURN SQL_API_FN SQLTables (SQLHSTMT hstmt,
SQLCHAR FAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLCHAR FAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLCHAR FAR *szTableName,
SQLSMALLINT cbTableName,
SQLCHAR FAR *szTableType,
SQLSMALLINT cbTableType);
SQLRETURN SQL_API SQLNextResult (SQLHSTMT hstmtSource,
SQLHSTMT hstmtTarget);
/* UNICODE versions */
#ifdef ODBC64
SQLRETURN SQL_API SQLColAttributeW(
SQLHSTMT hstmt,
SQLUSMALLINT iCol,
SQLUSMALLINT iField,
SQLPOINTER pCharAttr,
SQLSMALLINT cbCharAttrMax,
SQLSMALLINT *pcbCharAttr,
SQLLEN *pNumAttr);
#else
SQLRETURN SQL_API SQLColAttributeW(
SQLHSTMT hstmt,
SQLUSMALLINT iCol,
SQLUSMALLINT iField,
SQLPOINTER pCharAttr,
SQLSMALLINT cbCharAttrMax,
SQLSMALLINT *pcbCharAttr,
SQLPOINTER pNumAttr);
#endif
SQLRETURN SQL_API SQLColAttributesW(
SQLHSTMT hstmt,
SQLUSMALLINT icol,
SQLUSMALLINT fDescType,
SQLPOINTER rgbDesc,
SQLSMALLINT cbDescMax,
SQLSMALLINT *pcbDesc,
SQLLEN *pfDesc);
SQLRETURN SQL_API SQLConnectW(
SQLHDBC hdbc,
SQLWCHAR *szDSN,
SQLSMALLINT cbDSN,
SQLWCHAR *szUID,
SQLSMALLINT cbUID,
SQLWCHAR *szAuthStr,
SQLSMALLINT cbAuthStr);
SQLRETURN SQL_API SQLConnectWInt(
SQLHDBC hdbc,
SQLWCHAR *szDSN,
SQLSMALLINT cbDSN,
SQLWCHAR *szUID,
SQLSMALLINT cbUID,
SQLWCHAR *szAuthStr,
SQLSMALLINT cbAuthStr);
SQLRETURN SQL_API SQLDescribeColW(
SQLHSTMT hstmt,
SQLUSMALLINT icol,
SQLWCHAR *szColName,
SQLSMALLINT cbColNameMax,
SQLSMALLINT *pcbColName,
SQLSMALLINT *pfSqlType,
SQLULEN *pcbColDef,
SQLSMALLINT *pibScale,
SQLSMALLINT *pfNullable);
SQLRETURN SQL_API SQLErrorW(
SQLHENV henv,
SQLHDBC hdbc,
SQLHSTMT hstmt,
SQLWCHAR *szSqlState,
SQLINTEGER *pfNativeError,
SQLWCHAR *szErrorMsg,
SQLSMALLINT cbErrorMsgMax,
SQLSMALLINT *pcbErrorMsg);
SQLRETURN SQL_API SQLExecDirectW(
SQLHSTMT hstmt,
SQLWCHAR *szSqlStr,
SQLINTEGER cbSqlStr);
SQLRETURN SQL_API SQLGetConnectAttrW(
SQLHDBC hdbc,
SQLINTEGER fAttribute,
SQLPOINTER rgbValue,
SQLINTEGER cbValueMax,
SQLINTEGER *pcbValue);
SQLRETURN SQL_API SQLGetCursorNameW(
SQLHSTMT hstmt,
SQLWCHAR *szCursor,
SQLSMALLINT cbCursorMax,
SQLSMALLINT *pcbCursor);
SQLRETURN SQL_API SQLSetDescFieldW(SQLHDESC DescriptorHandle,
SQLSMALLINT RecNumber,
SQLSMALLINT FieldIdentifier,
SQLPOINTER Value,
SQLINTEGER BufferLength);
SQLRETURN SQL_API SQLGetDescFieldW(
SQLHDESC hdesc,
SQLSMALLINT iRecord,
SQLSMALLINT iField,
SQLPOINTER rgbValue,
SQLINTEGER cbValueMax,
SQLINTEGER *pcbValue);
SQLRETURN SQL_API SQLGetDescRecW(
SQLHDESC hdesc,
SQLSMALLINT iRecord,
SQLWCHAR *szName,
SQLSMALLINT cbNameMax,
SQLSMALLINT *pcbName,
SQLSMALLINT *pfType,
SQLSMALLINT *pfSubType,
SQLLEN *pLength,
SQLSMALLINT *pPrecision,
SQLSMALLINT *pScale,
SQLSMALLINT *pNullable);
SQLRETURN SQL_API SQLGetDiagFieldW(
SQLSMALLINT fHandleType,
SQLHANDLE handle,
SQLSMALLINT iRecord,
SQLSMALLINT fDiagField,
SQLPOINTER rgbDiagInfo,
SQLSMALLINT cbDiagInfoMax,
SQLSMALLINT *pcbDiagInfo);
SQLRETURN SQL_API SQLGetDiagRecW(
SQLSMALLINT fHandleType,
SQLHANDLE handle,
SQLSMALLINT iRecord,
SQLWCHAR *szSqlState,
SQLINTEGER *pfNativeError,
SQLWCHAR *szErrorMsg,
SQLSMALLINT cbErrorMsgMax,
SQLSMALLINT *pcbErrorMsg);
SQLRETURN SQL_API_FN SQLGetEnvAttrW(
SQLHENV hEnv,
SQLINTEGER fAttribute,
SQLPOINTER pParam,
SQLINTEGER cbParamMax,
SQLINTEGER * pcbParam );
SQLRETURN SQL_API SQLPrepareW(
SQLHSTMT hstmt,
SQLWCHAR *szSqlStr,
SQLINTEGER cbSqlStr);
SQLRETURN SQL_API_FN SQLExtendedPrepareW( SQLHSTMT hStmt,
SQLWCHAR * pszSqlStrIn,
SQLINTEGER cbSqlStr,
SQLINTEGER cPars,
SQLSMALLINT sStmtType,
SQLINTEGER cStmtAttrs,
SQLINTEGER * piStmtAttr,
SQLINTEGER * pvParams );
SQLRETURN SQL_API SQLSetConnectAttrW(
SQLHDBC hdbc,
SQLINTEGER fAttribute,
SQLPOINTER rgbValue,
SQLINTEGER cbValue);
SQLRETURN SQL_API SQLSetCursorNameW(
SQLHSTMT hstmt,
SQLWCHAR *szCursor,
SQLSMALLINT cbCursor);
SQLRETURN SQL_API_FN SQLSetEnvAttrW(
SQLHENV hEnv,
SQLINTEGER fAttribute,
SQLPOINTER pParam,
SQLINTEGER cbParam );
SQLRETURN SQL_API SQLColumnsW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szTableName,
SQLSMALLINT cbTableName,
SQLWCHAR *szColumnName,
SQLSMALLINT cbColumnName);
SQLRETURN SQL_API SQLGetInfoW(
SQLHDBC hdbc,
SQLUSMALLINT fInfoType,
SQLPOINTER rgbInfoValue,
SQLSMALLINT cbInfoValueMax,
SQLSMALLINT *pcbInfoValue);
SQLRETURN SQL_API_FN SQLGetConnectOptionW(
SQLHDBC hDbc,
SQLUSMALLINT fOptionIn,
SQLPOINTER pvParam );
SQLRETURN SQL_API_FN SQLSetConnectOptionW(
SQLHDBC hDbc,
SQLUSMALLINT fOptionIn,
SQLULEN vParam );
SQLRETURN SQL_API_FN SQLGetTypeInfoW(
SQLHSTMT hstmt,
SQLSMALLINT fSqlType);
SQLRETURN SQL_API SQLSpecialColumnsW(
SQLHSTMT hstmt,
SQLUSMALLINT fColType,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szTableName,
SQLSMALLINT cbTableName,
SQLUSMALLINT fScope,
SQLUSMALLINT fNullable);
SQLRETURN SQL_API SQLStatisticsW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szTableName,
SQLSMALLINT cbTableName,
SQLUSMALLINT fUnique,
SQLUSMALLINT fAccuracy);
SQLRETURN SQL_API SQLTablesW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szTableName,
SQLSMALLINT cbTableName,
SQLWCHAR *szTableType,
SQLSMALLINT cbTableType);
SQLRETURN SQL_API SQLDataSourcesW(
SQLHENV henv,
SQLUSMALLINT fDirection,
SQLWCHAR *szDSN,
SQLSMALLINT cbDSNMax,
SQLSMALLINT *pcbDSN,
SQLWCHAR *szDescription,
SQLSMALLINT cbDescriptionMax,
SQLSMALLINT *pcbDescription);
SQLRETURN SQL_API SQLDriverConnectW(
SQLHDBC hdbc,
SQLHWND hwnd,
SQLWCHAR *szConnStrIn,
SQLSMALLINT cbConnStrIn,
SQLWCHAR *szConnStrOut,
SQLSMALLINT cbConnStrOutMax,
SQLSMALLINT *pcbConnStrOut,
SQLUSMALLINT fDriverCompletion);
SQLRETURN SQL_API SQLBrowseConnectW(
SQLHDBC hdbc,
SQLWCHAR *szConnStrIn,
SQLSMALLINT cbConnStrIn,
SQLWCHAR *szConnStrOut,
SQLSMALLINT cbConnStrOutMax,
SQLSMALLINT *pcbConnStrOut);
SQLRETURN SQL_API SQLColumnPrivilegesW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szTableName,
SQLSMALLINT cbTableName,
SQLWCHAR *szColumnName,
SQLSMALLINT cbColumnName);
SQLRETURN SQL_API SQLGetStmtAttrW(
SQLHSTMT hstmt,
SQLINTEGER fAttribute,
SQLPOINTER rgbValue,
SQLINTEGER cbValueMax,
SQLINTEGER *pcbValue);
SQLRETURN SQL_API SQLSetStmtAttrW(
SQLHSTMT hstmt,
SQLINTEGER fAttribute,
SQLPOINTER rgbValue,
SQLINTEGER cbValueMax);
SQLRETURN SQL_API SQLForeignKeysW(
SQLHSTMT hstmt,
SQLWCHAR *szPkCatalogName,
SQLSMALLINT cbPkCatalogName,
SQLWCHAR *szPkSchemaName,
SQLSMALLINT cbPkSchemaName,
SQLWCHAR *szPkTableName,
SQLSMALLINT cbPkTableName,
SQLWCHAR *szFkCatalogName,
SQLSMALLINT cbFkCatalogName,
SQLWCHAR *szFkSchemaName,
SQLSMALLINT cbFkSchemaName,
SQLWCHAR *szFkTableName,
SQLSMALLINT cbFkTableName);
SQLRETURN SQL_API SQLNativeSqlW(
SQLHDBC hdbc,
SQLWCHAR *szSqlStrIn,
SQLINTEGER cbSqlStrIn,
SQLWCHAR *szSqlStr,
SQLINTEGER cbSqlStrMax,
SQLINTEGER *pcbSqlStr);
SQLRETURN SQL_API SQLPrimaryKeysW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szTableName,
SQLSMALLINT cbTableName);
SQLRETURN SQL_API SQLProcedureColumnsW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szProcName,
SQLSMALLINT cbProcName,
SQLWCHAR *szColumnName,
SQLSMALLINT cbColumnName);
SQLRETURN SQL_API SQLProceduresW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szProcName,
SQLSMALLINT cbProcName);
SQLRETURN SQL_API SQLTablePrivilegesW(
SQLHSTMT hstmt,
SQLWCHAR *szCatalogName,
SQLSMALLINT cbCatalogName,
SQLWCHAR *szSchemaName,
SQLSMALLINT cbSchemaName,
SQLWCHAR *szTableName,
SQLSMALLINT cbTableName);
/*
* DB2 specific CLI APIs
*/
SQLRETURN SQL_API_FN SQLBindFileToCol (SQLHSTMT hstmt,
SQLUSMALLINT icol,
SQLCHAR FAR *FileName,
SQLSMALLINT FAR *FileNameLength,
SQLUINTEGER FAR *FileOptions,
SQLSMALLINT MaxFileNameLength,
SQLINTEGER FAR *StringLength,
SQLINTEGER FAR *IndicatorValue);
SQLRETURN SQL_API_FN SQLBindFileToParam(SQLHSTMT hstmt,
SQLUSMALLINT ipar,
SQLSMALLINT fSqlType,
SQLCHAR FAR *FileName,
SQLSMALLINT FAR *FileNameLength,
SQLUINTEGER FAR *FileOptions,
SQLSMALLINT MaxFileNameLength,
SQLINTEGER FAR *IndicatorValue);
SQLRETURN SQL_API_FN SQLGetLength (SQLHSTMT hstmt,
SQLSMALLINT LocatorCType,
SQLINTEGER Locator,
SQLINTEGER FAR *StringLength,
SQLINTEGER FAR *IndicatorValue);
SQLRETURN SQL_API_FN SQLGetPosition (SQLHSTMT hstmt,
SQLSMALLINT LocatorCType,
SQLINTEGER SourceLocator,
SQLINTEGER SearchLocator,
SQLCHAR FAR *SearchLiteral,
SQLINTEGER SearchLiteralLength,
SQLUINTEGER FromPosition,
SQLUINTEGER FAR *LocatedAt,
SQLINTEGER FAR *IndicatorValue);
SQLRETURN SQL_API_FN SQLGetSQLCA (SQLHENV henv,
SQLHDBC hdbc,
SQLHSTMT hstmt,
struct sqlca FAR *pSqlca );
SQLRETURN SQL_API_FN SQLGetSubString (SQLHSTMT hstmt,
SQLSMALLINT LocatorCType,
SQLINTEGER SourceLocator,
SQLUINTEGER FromPosition,
SQLUINTEGER ForLength,
SQLSMALLINT TargetCType,
SQLPOINTER rgbValue,
SQLINTEGER cbValueMax,
SQLINTEGER FAR *StringLength,
SQLINTEGER FAR *IndicatorValue);
SQLRETURN SQL_API_FN SQLSetColAttributes (SQLHSTMT hstmt,
SQLUSMALLINT icol,
SQLCHAR FAR *pszColName,
SQLSMALLINT cbColName,
SQLSMALLINT fSQLType,
SQLUINTEGER cbColDef,
SQLSMALLINT ibScale,
SQLSMALLINT fNullable);
/*
* Set active connection API, for use in conjunction with embedded
* SQL programming only.
*/
SQLRETURN SQL_API_FN SQLSetConnection (SQLHDBC hdbc);
/*
* APIs defined only by X/Open CLI
*/
SQLRETURN SQL_API_FN SQLGetEnvAttr (SQLHENV henv,
SQLINTEGER Attribute,
SQLPOINTER Value,
SQLINTEGER BufferLength,
SQLINTEGER FAR *StringLength);
SQLRETURN SQL_API_FN SQLSetEnvAttr (SQLHENV henv,
SQLINTEGER Attribute,
SQLPOINTER Value,
SQLINTEGER StringLength);
SQLRETURN SQL_API_FN SQLBindParam( SQLHSTMT StatementHandle,
SQLUSMALLINT ParameterNumber,
SQLSMALLINT ValueType,
SQLSMALLINT ParameterType,
SQLULEN LengthPrecision,
SQLSMALLINT ParameterScale,
SQLPOINTER ParameterValue,
SQLLEN *StrLen_or_Ind);
/*
* Data link functions.
*/
SQLRETURN SQL_API_FN SQLBuildDataLink( SQLHSTMT hStmt,
SQLCHAR FAR * pszLinkType,
SQLINTEGER cbLinkType,
SQLCHAR FAR * pszDataLocation,
SQLINTEGER cbDataLocation,
SQLCHAR FAR * pszComment,
SQLINTEGER cbComment,
SQLCHAR FAR * pDataLink,
SQLINTEGER cbDataLinkMax,
SQLINTEGER FAR * pcbDataLink );
SQLRETURN SQL_API_FN SQLGetDataLinkAttr( SQLHSTMT hStmt,
SQLSMALLINT fAttrType,
SQLCHAR FAR * pDataLink,
SQLINTEGER cbDataLink,
SQLPOINTER pAttribute,
SQLINTEGER cbAttributeMax,
SQLINTEGER * pcbAttribute );
/*
* DB2 CLI APIs
*/
SQLRETURN SQL_API_FN SQLExtendedPrepare( SQLHSTMT hstmt,
SQLCHAR * pszSqlStmt,
SQLINTEGER cbSqlStmt,
SQLINTEGER cPars,
SQLSMALLINT sStmtType,
SQLINTEGER cStmtAttrs,
SQLINTEGER * piStmtAttr,
SQLINTEGER * pvParams );
SQLRETURN SQL_API_FN SQLExtendedBind (SQLHSTMT hstmt,
SQLSMALLINT fBindCol,
SQLSMALLINT cRecords,
SQLSMALLINT * pfCType,
SQLPOINTER * rgbValue,
SQLINTEGER * cbValueMax,
SQLUINTEGER * puiPrecisionCType,
SQLSMALLINT * psScaleCType,
SQLINTEGER ** pcbValue,
SQLINTEGER ** piIndicatorPtr,
SQLSMALLINT * pfParamType,
SQLSMALLINT * pfSQLType,
SQLUINTEGER * pcbColDef,
SQLSMALLINT * pibScale );
#ifdef __cplusplus
}
#endif
#define SQL_C_WCHAR SQL_WCHAR
#ifdef UNICODE
#define SQL_C_TCHAR SQL_C_WCHAR
typedef SQLWCHAR SQLTCHAR;
#else
#define SQL_C_TCHAR SQL_C_CHAR
typedef SQLCHAR SQLTCHAR;
#endif
#define SQLConnectWInt SQLConnectW
#ifdef UNICODE
#define SQLColAttribute SQLColAttributeW
#define SQLColAttributes SQLColAttributesW
#define SQLConnect SQLConnectW
#define SQLDescribeCol SQLDescribeColW
#define SQLError SQLErrorW
#define SQLExecDirect SQLExecDirectW
#define SQLGetConnectAttr SQLGetConnectAttrW
#define SQLGetCursorName SQLGetCursorNameW
#define SQLGetDescField SQLGetDescFieldW
#define SQLGetDescRec SQLGetDescRecW
#define SQLGetDiagField SQLGetDiagFieldW
#define SQLGetDiagRec SQLGetDiagRecW
#define SQLGetEnvAttr SQLGetEnvAttrW
#define SQLPrepare SQLPrepareW
#define SQLSetConnectAttr SQLSetConnectAttrW
#define SQLSetCursorName SQLSetCursorNameW
#define SQLSetDescField SQLSetDescFieldW
#define SQLSetEnvAttr SQLSetEnvAttrW
#define SQLSetStmtAttr SQLSetStmtAttrW
#define SQLGetStmtAttr SQLGetStmtAttrW
#define SQLColumns SQLColumnsW
#define SQLGetInfo SQLGetInfoW
#define SQLSpecialColumns SQLSpecialColumnsW
#define SQLStatistics SQLStatisticsW
#define SQLTables SQLTablesW
#define SQLDataSources SQLDataSourcesW
#define SQLDriverConnect SQLDriverConnectW
#define SQLBrowseConnect SQLBrowseConnectW
#define SQLColumnPrivileges SQLColumnPrivilegesW
#define SQLForeignKeys SQLForeignKeysW
#define SQLNativeSql SQLNativeSqlW
#define SQLPrimaryKeys SQLPrimaryKeysW
#define SQLProcedureColumns SQLProcedureColumnsW
#define SQLProcedures SQLProceduresW
#define SQLTablePrivileges SQLTablePrivilegesW
#endif /* UNICODE */
#ifdef DB2_WINSOCKAPI_
#undef _WINSOCKAPI_
#undef DB2_WINSOCKAPI_
#endif
#endif /* SQL_H_SQLCLI1 */