/******************************************************************************
 *
 * Source File Name = sqlcli1.h
 *
 * (C) COPYRIGHT International Business Machines Corp. 1993, 2014
 * 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_SQLCREATEDB           1258
#define  SQL_API_SQLDROPDB             1259
#define  SQL_API_SQLCREATEPKG          1260
#define  SQL_API_SQLDROPPKG            1261
#define  SQL_API_SQLEXTENDEDPREPARE    1296
#define  SQL_API_SQLEXTENDEDBIND       1297
#define  SQL_API_SQLEXTENDEDDESCRIBE   1298
#define  SQL_API_SQLRELOADCONFIG       1299

#define  SQL_API_SQLFETCHSCROLL        1021
#define  SQL_API_SQLGETLENGTH          1022
#define  SQL_API_SQLGETPOSITION        1023
#define  SQL_API_SQLGETSUBSTRING       1024

#define  SQL_API_SQLEXTENDEDPROCEDURES       1025
#define  SQL_API_SQLEXTENDEDPROCEDURECOLUMNS 1026

#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
#define SQL_DROP_MODULE                      2600
#define SQL_MODULE_USAGE                     2601
#define SQL_CREATE_MODULE                    2602
#define SQL_MAX_MODULE_NAME_LEN              2603
#define SQL_DRIVER_BLDLEVEL                  2604


/*
 *  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_CONFIG_KEYWORDS                174
#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_INPUT_CHAR_CONVFACTOR           2581
#define  SQL_OUTPUT_CHAR_CONVFACTOR          2582
#define  SQL_ATTR_REPLACE_QUOTED_LITERALS    2586
#define  SQL_ATTR_REPORT_TIMESTAMP_TRUNC_AS_WARN    2587
#define  SQL_ATTR_CLIENT_ENCALG              2589
#define  SQL_ATTR_CONCURRENT_ACCESS_RESOLUTION  2595      /*  @d348892lmy */
#define  SQL_ATTR_REPORT_SEAMLESSFAILOVER_WARNING 2605
#define  SQL_CONCURRENT_ACCESS_RESOLUTION_UNSET    0
#define  SQL_USE_CURRENTLY_COMMITTED 1
#define  SQL_WAIT_FOR_OUTCOME 2
#define  SQL_SKIP_LOCKED_DATA  3

/* define constants for Seamless failover warning */
#define  SQL_REPORT_SEAMLESSFAILOVER_WARNING_YES SQL_TRUE
#define  SQL_REPORT_SEAMLESSFAILOVER_WARNING_NO  SQL_FALSE

/*
 *  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
#define SQL_CLI_STMT_SET                       62
#define SQL_CLI_STMT_ALTER_PROCEDURE           63
#define SQL_CLI_STMT_CLOSE_DATABASE            64
#define SQL_CLI_STMT_CREATE_DATABASE           65
#define SQL_CLI_STMT_DROP_DATABASE             66
#define SQL_CLI_STMT_ANONYMOUS_BLOCK           72

/*
 *  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
#define SQL_TXN_IDS_CURSOR_STABILITY        0x00000040L
#define SQL_TRANSACTION_IDS_CURSOR_STABILITY    SQL_TXN_IDS_CURSOR_STABILITY
#define SQL_TXN_IDS_LAST_COMMITTED          0x00000080L
#define SQL_TRANSACTION_IDS_LAST_COMMITTED      SQL_TXN_IDS_LAST_COMMITTED

/* 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
#define  SQL_ATTR_RETRYONERROR        121

/*
 *  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
#define  SQL_ATTR_GET_GENERATED_VALUE        2583
#define  SQL_ATTR_GET_SERIAL_VALUE           2584
#define  SQL_ATTR_INTERLEAVED_PUTDATA        2591
#define  SQL_ATTR_FORCE_ROLLBACK             2596
#define  SQL_ATTR_STMT_CONCENTRATOR          2597

/* define constants for statement concentrator attribute */
#define SQL_STMT_CONCENTRATOR_OFF   1
#define SQL_STMT_CONCENTRATOR_WITH_LITERALS 2

#define SQL_INFO_LAST                         174
#define SQL_INFO_DRIVER_START                 1000
/* SQL_ATTR_FORCE_ROLLBACK option */
#define SQL_FORCE_ROLLBACK_ON             1
#define SQL_FORCE_ROLLBACK_OFF            0
#define SQL_FORCE_ROLLBACK_DEFAULT        SQL_FORCE_ROLLBACK_OFF

/*
 *  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_RETRYONERROR options */
#define SQL_RETRYONERROR_OFF            0
#define SQL_RETRYONERROR_ON             1
#define SQL_RETRYONERROR_DEFAULT        SQL_RETRYONERROR_ON

/* SQL_RETRYBINDONERROR options */
#define SQL_RETRYBINDONERROR_OFF            0
#define SQL_RETRYBINDONERROR_ON             1
#define SQL_RETRYBINDONERROR_DEFAULT        SQL_RETRYBINDONERROR_ON

/* SQL_ATTR_ALLOW_INTERLEAVED_GETDATA options */
#define SQL_ALLOW_INTERLEAVED_GETDATA_OFF       0
#define SQL_ALLOW_INTERLEAVED_GETDATA_ON        1
#define SQL_ALLOW_INTERLEAVED_GETDATA_DEFAULT   SQL_ALLOW_INTERLEAVED_GETDATA_OFF

/* SQL_ATTR_INTERLEAVED_STREAM_PUTDATA options */
#define SQL_INTERLEAVED_STREAM_PUTDATA_OFF       0
#define SQL_INTERLEAVED_STREAM_PUTDATA_ON        1
#define SQL_INTERLEAVED_STREAM_PUTDATA_DEFAULT   SQL_ALLOW_INTERLEAVED_STREAM_PUTDATA_OFF

/* SQL_OVERRIDE_CODEPAGE option. This is used for skipping codepage conversion for char & graphic columns */
#define SQL_OVERRIDE_CODEPAGE_ON 1
#define SQL_OVERRIDE_CODEPAGE_OFF 0

/* 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_DRDAWRAPPER      5
#define SQL_APP_TYPE_OCI              6
#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
#define SQL_PROCESSCTL_MULTICONNECT3  0x00000008L

/* 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_CLIENT_ENCALG */
#define SQL_CLIENT_ENCALG_NOT_SET           0
#define SQL_CLIENT_ENCALG_ANY               1
#define SQL_CLIENT_ENCALG_AES_ONLY          2

/* Options for SQL_ATTR_COMMITONEOF */
#define SQL_COMMITONEOF_OFF          0
#define SQL_COMMITONEOF_ON           1

/* 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_NONATMOIC_BUFFER_INSERT           2588
#define SQL_ATTR_ROWCOUNT_PREFETCH                 2592
#define SQL_ATTR_PING_REQUEST_PACKET_SIZE          2593
#define SQL_ATTR_PING_NTIMES                       2594
#define SQL_ATTR_ALLOW_INTERLEAVED_GETDATA         2599
#define SQL_ATTR_INTERLEAVED_STREAM_PUTDATA        3000
#define SQL_ATTR_FET_BUF_SIZE                      3001
#define SQL_ATTR_CLIENT_CODEPAGE                   3002
#define SQL_ATTR_EXTENDED_INDICATORS               3003
#define SQL_ATTR_SESSION_TIME_ZONE                 3004
#define SQL_ATTR_CLIENT_TIME_ZONE                  3005
/* A Connection attribute which controls the collection of network statistics */
/* for a connection.  The statistics can be retrieved by calling */
/* SQLGetDiagField() */
/* with the SQL_DIAG_NETWORK_STATISTICS DiagIdentifier. */
#define SQL_ATTR_NETWORK_STATISTICS                3006
#define SQL_ATTR_OVERRIDE_CHARACTER_CODEPAGE       3007
#define SQL_ATTR_GET_LATEST_MEMBER                 3008	
#define SQL_ATTR_CO_CAPTUREONPREPARE               3009
#define SQL_ATTR_RETRYBINDONERROR                  3010
#define SQL_ATTR_COMMITONEOF                       3011
#define SQL_ATTR_PARC_BATCH                        3012
#define SQL_ATTR_COLUMNWISE_MRI                    3013
#define SQL_ATTR_OVERRIDE_CODEPAGE                 3014
#define SQL_ATTR_SQLCODEMAP                        3015
#define SQL_ATTR_ISREADONLYSQL                     3016
#define SQL_ATTR_DBC_SYS_NAMING                    3017
#define SQL_ATTR_FREE_MEMORY_ON_STMTCLOSE          3018
#define SQL_ATTR_OVERRIDE_PRIMARY_AFFINITY         3020
#define SQL_ATTR_STREAM_OUTPUTLOB_ON_CALL          3021
#define SQL_ATTR_CACHE_USRLIBL                     3022
#define SQL_ATTR_GET_LATEST_MEMBER_NAME            3023
#define SQL_ATTR_INFO_CRRTKN                       3024
#define SQL_ATTR_DATE_FMT                          3025
#define SQL_ATTR_DATE_SEP                          3026 
#define SQL_ATTR_TIME_FMT                          3027 
#define SQL_ATTR_TIME_SEP                          3028 
#define SQL_ATTR_DECIMAL_SEP                       3029
#define SQL_ATTR_READ_ONLY_CONNECTION              3030 
#define SQL_ATTR_CONFIG_KEYWORDS_ARRAY_SIZE        3031
#define SQL_ATTR_CONFIG_KEYWORDS_MAXLEN            3032 
#define SQL_ATTR_RETRY_ON_MERGE                    3033 
#define SQL_ATTR_DETECT_READ_ONLY_TXN              3034
    
#define SQL_DM_DROP_MODULE                         0x00000001L
#define SQL_DM_RESTRICT                            0x00000002L
#define SQL_MU_PROCEDURE_INVOCATION                0x00000001L
#define SQL_CM_CREATE_MODULE                       0x00000001L
#define SQL_CM_AUTHORIZATION                       0x00000002L

#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

/* Connection Attr which cud be set to Enable or
 * Disable Sysplex
 */
#define SQL_ATTR_DISABLE_SYSPLEX       2590
	
#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

/* SQL_ATTR_PARC_BATCH values */
#define SQL_PARC_BATCH_ENABLE         1
#define SQL_PARC_BATCH_DISABLE        0

/* SQL_ATTR_SQLCODEMAP values */
#define SQL_SQLCODEMAP_NOMAP          1
#define SQL_SQLCODEMAP_MAP            2

/* 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
/* A DiagIdentifier which can be used to query network statistics for a */
/* connection.  */
#define SQL_DIAG_NETWORK_STATISTICS        2560

/*
 *  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
#define SQL_ATTR_MESSAGE_LINE_LENGTH   2580
#define SQL_ATTR_ENABLE_IFXENV         2585
#define SQL_ATTR_TRACENOHEADER         2598
#define SQL_ATTR_DB2TRC_STARTUP_SIZE   3019
/*
 *  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

/*
 * Options for SQL_ATTR_ROWCOUNT_PREFETCH
 */
#define SQL_ROWCOUNT_PREFETCH_OFF   0
#define SQL_ROWCOUNT_PREFETCH_ON    1

/* 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

/* Options for SQL_ATTR_EXTENDED_INDICATOR */
#define SQL_EXTENDED_INDICATOR_NOT_SET 0
#define SQL_EXTENDED_INDICATOR_ENABLE  1
#define SQL_EXTENDED_INDICATOR_DISABLE 2

/* Options for SQL_ATTR_COLUMNWISE_MRI */
#define SQL_COLUMNWISE_MRI_ON    1
#define SQL_COLUMNWISE_MRI_OFF   0

/* Options for SQL_ATTR_ISREADONLYSQL */
#define SQL_ISREADONLYSQL_YES    1
#define SQL_ISREADONLYSQL_NO     0


/* Options for SQL_ATTR_FREE_MEMORY_ON_STMTCLOSE */
#define SQL_FREE_MEMORY_ON_STMTCLOSE_YES    1
#define SQL_FREE_MEMORY_ON_STMTCLOSE_NO     0

/* Options for SQL_ATTR_CACHE_USRLIBL */
#define SQL_ATTR_CACHE_USRLIBL_YES            0
#define SQL_ATTR_CACHE_USRLIBL_NO             1
#define SQL_ATTR_CACHE_USRLIBL_REFRESH        2    

/* Options for DATE/TIME/DECIMAL environment/connection attributes */
#define SQL_IBMi_FMT_ISO                  1
#define SQL_IBMi_FMT_USA                  2
#define SQL_IBMi_FMT_EUR                  3
#define SQL_IBMi_FMT_JIS                  4
#define SQL_IBMi_FMT_MDY                  5
#define SQL_IBMi_FMT_DMY                  6
#define SQL_IBMi_FMT_YMD                  7
#define SQL_IBMi_FMT_JUL                  8
#define SQL_IBMi_FMT_HMS                  9
#define SQL_IBMi_FMT_JOB                  10

#define SQL_SEP_SLASH                     1
#define SQL_SEP_DASH                      2
#define SQL_SEP_PERIOD                    3
#define SQL_SEP_COMMA                     4
#define SQL_SEP_BLANK                     5
#define SQL_SEP_COLON                     6
#define SQL_SEP_JOB                       7

/* 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

/* SQLReloadConfig - Config Type */
#define DSD_ACR_AFFINITY    0x00000001


/*
 * 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

/* Options for SQL_ATTR_NETWORK_STATISTICS */
#define SQL_NETWORK_STATISTICS_ON_SKIP_NOSERVER 2
#define SQL_NETWORK_STATISTICS_ON               1
#define SQL_NETWORK_STATISTICS_OFF              0
#define SQL_NETWORK_STATISTICS_DEFAULT          SQL_NETWORK_STATISTICS_OFF

/* Options for SQL_ATTR_READ_ONLY_CONNECTION */
#define SQL_READ_ONLY_CONNECTION_ON  1
#define SQL_READ_ONLY_CONNECTION_OFF 0
#define SQL_READ_ONLY_CONNECTION_DEFAULT SQL_READ_ONLY_CONNECTION_OFF 

#define SQL_UNASSIGNED            (-7)

/* Options for SQL_ATTR_DETECT_READ_ONLY_TXN */
#define SQL_DETECT_READ_ONLY_TXN_ENABLE  1
#define SQL_DETECT_READ_ONLY_TXN_DISABLE 0    
   
/* The SQL_NET_STATS structure used when calling the SQLGetDiagField() API */
/* with a DiagIdentifier of SQL_DIAG_NETWORK_STATISTICS. */
typedef struct SQL_NET_STATS {
    SQLINTEGER iNetStatsLength;          /* Total structure length */
    SQLUBIGINT uiNetStatsServerTime;     /* Accumulated time spent in server */
                                         /* since reset (microseconds) */
    SQLUBIGINT uiNetStatsNetworkTime;    /* Accumulated network+server time */
                                         /* since reset (microseconds) */
    SQLUBIGINT uiNetStatsBytesSent;      /* Accumulated bytes sent since reset */
    SQLUBIGINT uiNetStatsBytesReceived;  /* Accumulated bytes received reset */
    SQLUBIGINT uiNetStatsRoundTrips;     /* Accumulated network round trips */
                                         /* since reset */
} SQL_NET_STATS;



/*
 *  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 SQLExtendedProcedureColumnsW(
    SQLHSTMT           hstmt,
    SQLWCHAR        *szCatalogName,
    SQLSMALLINT        cbCatalogName,
    SQLWCHAR        *szSchemaName,
    SQLSMALLINT        cbSchemaName,
    SQLWCHAR        *szProcName,
    SQLSMALLINT        cbProcName,
    SQLWCHAR        *szColumnName,
    SQLSMALLINT        cbColumnName,
    SQLWCHAR        *szModuleName,
    SQLSMALLINT        cbModuleName );

SQLRETURN SQL_API SQLExtendedProceduresW(
    SQLHSTMT           hstmt,
    SQLWCHAR        *szCatalogName,
    SQLSMALLINT        cbCatalogName,
    SQLWCHAR        *szSchemaName,
    SQLSMALLINT        cbSchemaName,
    SQLWCHAR        *szProcName,
    SQLSMALLINT        cbProcName,
    SQLWCHAR        *szModuleName,
    SQLSMALLINT        cbModuleName);

SQLRETURN SQL_API SQLTablePrivilegesW(
    SQLHSTMT           hstmt,
    SQLWCHAR        *szCatalogName,
    SQLSMALLINT        cbCatalogName,
    SQLWCHAR        *szSchemaName,
    SQLSMALLINT        cbSchemaName,
    SQLWCHAR        *szTableName,
    SQLSMALLINT        cbTableName);

SQLRETURN SQL_API SQLCreateDbW(
    SQLHDBC hDbc,
    SQLWCHAR * pszDBW,
    SQLINTEGER cbDB,
    SQLWCHAR * pszCodeSetW,
    SQLINTEGER cbCodeSet,
    SQLWCHAR * pszModeW,
    SQLINTEGER cbMode );

SQLRETURN SQL_API SQLDropDbW(
    SQLHDBC hDbc,
    SQLWCHAR * pszDBW,
    SQLINTEGER cbDB);

SQLRETURN SQL_API_FN SQLCreatePkgW(
    SQLHDBC    hDbc,
    SQLWCHAR * szBindFileNameIn,
    SQLINTEGER cbBindFileNameIn,
    SQLWCHAR * szBindOpts,
    SQLINTEGER cbBindOpts);

SQLRETURN SQL_API_FN SQLDropPkgW(
    SQLHDBC    hDbc,
    SQLWCHAR * szCollection,
    SQLINTEGER cbCollection,
    SQLWCHAR * szPackage,
    SQLINTEGER cbPackage);

/*
 * 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);

SQLRETURN SQL_API_FN SQLExtendedProcedures(
    SQLHSTMT           hstmt,
    SQLCHAR        *szCatalogName,
    SQLSMALLINT        cbCatalogName,
    SQLCHAR        *szSchemaName,
    SQLSMALLINT        cbSchemaName,
    SQLCHAR        *szProcName,
    SQLSMALLINT        cbProcName,
    SQLCHAR        *szModuleName,
    SQLSMALLINT        cbModuleName);

SQLRETURN SQL_API SQLExtendedProcedureColumns(
    SQLHSTMT           hstmt,
    SQLCHAR        *szCatalogName,
    SQLSMALLINT        cbCatalogName,
    SQLCHAR        *szSchemaName,
    SQLSMALLINT        cbSchemaName,
    SQLCHAR        *szProcName,
    SQLSMALLINT        cbProcName,
    SQLCHAR        *szColumnName,
    SQLSMALLINT        cbColumnName,
    SQLCHAR        *szModuleName,
    SQLSMALLINT        cbModuleName );

SQLRETURN SQL_API_FN  SQLReloadConfig  (SQLINTEGER config_property,
                                        SQLCHAR *DiagInfoString,
                                        SQLSMALLINT BufferLength,
                                        SQLSMALLINT *StringLengthPtr );

SQLRETURN SQL_API_FN  SQLReloadConfigW (SQLINTEGER config_property,
                                        SQLWCHAR *DiagInfoString,
                                        SQLSMALLINT BufferLength,
                                        SQLSMALLINT *StringLengthPtr );

SQLRETURN SQL_API_FN SQLGetPositionW(SQLHSTMT       hStmt,
                                     SQLSMALLINT    fCType,
                                     SQLINTEGER     iLocatorIn,
                                     SQLINTEGER     iPatternLocator,
                                     SQLWCHAR *     pszPatternLiteral,
                                     SQLINTEGER     cbPatternLiteral,
                                     SQLUINTEGER    iStartSearchAtIn,
                                     SQLUINTEGER *  piLocatedAtIn,
                                     SQLINTEGER *   piIndicatorValue);

/*
 *  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 );

SQLRETURN SQL_API_FN SQLExtendedDescribe( SQLHANDLE     hStmt,
                                          SQLSMALLINT   fDescribeCol,
                                          SQLUSMALLINT  iNumRecordsAllocated,
                                          SQLUSMALLINT *pusNumRecords,
                                          SQLCHAR      *pNames,
                                          SQLSMALLINT   sNameMaxByteLen,
                                          SQLSMALLINT  *psNameCharLen,
                                          SQLSMALLINT  *psSQLType,
                                          SQLULEN      *pcbColDef,
                                          SQLULEN      *pcbDisplaySize,
                                          SQLSMALLINT  *psScale,
                                          SQLSMALLINT  *psNullable,
                                          SQLSMALLINT  *psParamType,
                                          SQLLEN       *piCardinality );

SQLRETURN SQL_API_FN SQLDropPkg         ( SQLHDBC    hDbc,
                                          SQLCHAR   *szCollection,
                                          SQLINTEGER cbCollection,
                                          SQLCHAR   *szPackage,
                                          SQLINTEGER cbPackage);


#ifdef __cplusplus
}
#endif

#define  SQL_C_WCHAR         SQL_WCHAR
#ifdef UNICODE
#define SQL_C_TCHAR     SQL_C_WCHAR
#else
#define SQL_C_TCHAR     SQL_C_CHAR
#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
#define SQLExtendedProcedures SQLExtendedProceduresW
#define SQLExtendedProcedureColumns SQLExtendedProcedureColumnsW

#endif /* UNICODE */

#ifdef DB2_WINSOCKAPI_
#undef _WINSOCKAPI_
#undef DB2_WINSOCKAPI_
#endif

#endif /* SQL_H_SQLCLI1 */
