32 #define SQL_DIAG_SS_MSGSTATE (-1150)
33 #define SQL_DIAG_SS_LINE (-1154)
35 #define SQL_SOPT_SS_QUERYNOTIFICATION_TIMEOUT 1233
36 #define SQL_SOPT_SS_QUERYNOTIFICATION_MSGTEXT 1234
37 #define SQL_SOPT_SS_QUERYNOTIFICATION_OPTIONS 1235
39 #ifndef SQL_SS_LENGTH_UNLIMITED
40 #define SQL_SS_LENGTH_UNLIMITED 0
43 #ifndef SQL_COPT_SS_OLDPWD
44 #define SQL_COPT_SS_OLDPWD 1226
47 #define SQL_COPT_SS_BASE 1200
58 #ifndef BCPKEEPIDENTITY
59 #define BCPKEEPIDENTITY 8
65 #define BCP_DIRECTION_IN 1
67 #define SQL_COPT_SS_BCP (SQL_COPT_SS_BASE+19)
71 #define SQL_COPT_TDSODBC_IMPL_BASE 1500
72 #define SQL_COPT_TDSODBC_IMPL_BCP_INITA (SQL_COPT_TDSODBC_IMPL_BASE)
73 #define SQL_COPT_TDSODBC_IMPL_BCP_CONTROL (SQL_COPT_TDSODBC_IMPL_BASE+1)
74 #define SQL_COPT_TDSODBC_IMPL_BCP_COLPTR (SQL_COPT_TDSODBC_IMPL_BASE+2)
75 #define SQL_COPT_TDSODBC_IMPL_BCP_SENDROW (SQL_COPT_TDSODBC_IMPL_BASE+3)
76 #define SQL_COPT_TDSODBC_IMPL_BCP_BATCH (SQL_COPT_TDSODBC_IMPL_BASE+4)
77 #define SQL_COPT_TDSODBC_IMPL_BCP_DONE (SQL_COPT_TDSODBC_IMPL_BASE+5)
78 #define SQL_COPT_TDSODBC_IMPL_BCP_BIND (SQL_COPT_TDSODBC_IMPL_BASE+6)
79 #define SQL_COPT_TDSODBC_IMPL_BCP_INITW (SQL_COPT_TDSODBC_IMPL_BASE+7)
81 #define SQL_VARLEN_DATA -10
87 BCP_TYPE_SQLCHAR = 47,
88 #define BCP_TYPE_SQLCHAR BCP_TYPE_SQLCHAR
89 BCP_TYPE_SQLVARCHAR = 39,
90 #define BCP_TYPE_SQLVARCHAR BCP_TYPE_SQLVARCHAR
91 BCP_TYPE_SQLINTN = 38,
92 #define BCP_TYPE_SQLINTN BCP_TYPE_SQLINTN
93 BCP_TYPE_SQLINT1 = 48,
94 #define BCP_TYPE_SQLINT1 BCP_TYPE_SQLINT1
95 BCP_TYPE_SQLINT2 = 52,
96 #define BCP_TYPE_SQLINT2 BCP_TYPE_SQLINT2
97 BCP_TYPE_SQLINT4 = 56,
98 #define BCP_TYPE_SQLINT4 BCP_TYPE_SQLINT4
99 BCP_TYPE_SQLINT8 = 127,
100 #define BCP_TYPE_SQLINT8 BCP_TYPE_SQLINT8
101 BCP_TYPE_SQLFLT8 = 62,
102 #define BCP_TYPE_SQLFLT8 BCP_TYPE_SQLFLT8
103 BCP_TYPE_SQLDATETIME = 61,
104 #define BCP_TYPE_SQLDATETIME BCP_TYPE_SQLDATETIME
105 BCP_TYPE_SQLBIT = 50,
106 #define BCP_TYPE_SQLBIT BCP_TYPE_SQLBIT
107 BCP_TYPE_SQLBITN = 104,
108 #define BCP_TYPE_SQLBITN BCP_TYPE_SQLBITN
109 BCP_TYPE_SQLTEXT = 35,
110 #define BCP_TYPE_SQLTEXT BCP_TYPE_SQLTEXT
111 BCP_TYPE_SQLNTEXT = 99,
112 #define BCP_TYPE_SQLNTEXT BCP_TYPE_SQLNTEXT
113 BCP_TYPE_SQLIMAGE = 34,
114 #define BCP_TYPE_SQLIMAGE BCP_TYPE_SQLIMAGE
115 BCP_TYPE_SQLMONEY4 = 122,
116 #define BCP_TYPE_SQLMONEY4 BCP_TYPE_SQLMONEY4
117 BCP_TYPE_SQLMONEY = 60,
118 #define BCP_TYPE_SQLMONEY BCP_TYPE_SQLMONEY
119 BCP_TYPE_SQLDATETIME4 = 58,
120 #define BCP_TYPE_SQLDATETIME4 BCP_TYPE_SQLDATETIME4
121 BCP_TYPE_SQLREAL = 59,
122 BCP_TYPE_SQLFLT4 = 59,
123 #define BCP_TYPE_SQLREAL BCP_TYPE_SQLREAL
124 #define BCP_TYPE_SQLFLT4 BCP_TYPE_SQLFLT4
125 BCP_TYPE_SQLBINARY = 45,
126 #define BCP_TYPE_SQLBINARY BCP_TYPE_SQLBINARY
127 BCP_TYPE_SQLVOID = 31,
128 #define BCP_TYPE_SQLVOID BCP_TYPE_SQLVOID
129 BCP_TYPE_SQLVARBINARY = 37,
130 #define BCP_TYPE_SQLVARBINARY BCP_TYPE_SQLVARBINARY
131 BCP_TYPE_SQLNUMERIC = 108,
132 #define BCP_TYPE_SQLNUMERIC BCP_TYPE_SQLNUMERIC
133 BCP_TYPE_SQLDECIMAL = 106,
134 #define BCP_TYPE_SQLDECIMAL BCP_TYPE_SQLDECIMAL
135 BCP_TYPE_SQLFLTN = 109,
136 #define BCP_TYPE_SQLFLTN BCP_TYPE_SQLFLTN
137 BCP_TYPE_SQLMONEYN = 110,
138 #define BCP_TYPE_SQLMONEYN BCP_TYPE_SQLMONEYN
139 BCP_TYPE_SQLDATETIMN = 111,
140 #define BCP_TYPE_SQLDATETIMN BCP_TYPE_SQLDATETIMN
141 BCP_TYPE_SQLNVARCHAR = 103,
142 #define BCP_TYPE_SQLNVARCHAR BCP_TYPE_SQLNVARCHAR
143 BCP_TYPE_SQLUNIQUEID = 36,
144 #define BCP_TYPE_SQLUNIQUEID BCP_TYPE_SQLUNIQUEID
145 BCP_TYPE_SQLDATETIME2 = 42,
146 #define BCP_TYPE_SQLDATETIME2 BCP_TYPE_SQLDATETIME2
156 #define TDSODBC_INLINE __inline
158 #define TDSODBC_INLINE __inline__
161 struct tdsodbc_impl_bcp_init_params
169 static TDSODBC_INLINE RETCODE
170 bcp_initA(HDBC hdbc,
const char *tblname,
const char *hfile,
const char *errfile,
int direction)
172 struct tdsodbc_impl_bcp_init_params params = {tblname, hfile, errfile, direction};
173 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_INITA, ¶ms, SQL_IS_POINTER)) ? SUCCEED : FAIL;
176 static TDSODBC_INLINE RETCODE
177 bcp_initW(HDBC hdbc,
const char *tblname,
const char *hfile,
const char *errfile,
int direction)
179 struct tdsodbc_impl_bcp_init_params params = {tblname, hfile, errfile, direction};
180 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_INITW, ¶ms, SQL_IS_POINTER)) ? SUCCEED : FAIL;
183 struct tdsodbc_impl_bcp_control_params
189 static TDSODBC_INLINE RETCODE
192 struct tdsodbc_impl_bcp_control_params params = {field, value};
193 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_CONTROL, ¶ms, SQL_IS_POINTER)) ? SUCCEED : FAIL;
196 struct tdsodbc_impl_bcp_colptr_params
202 static TDSODBC_INLINE RETCODE
203 bcp_colptr(HDBC hdbc,
const BYTE * colptr,
int table_column)
205 struct tdsodbc_impl_bcp_colptr_params params = {colptr, table_column};
206 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_COLPTR, ¶ms, SQL_IS_POINTER)) ? SUCCEED : FAIL;
209 static TDSODBC_INLINE RETCODE
212 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_SENDROW, NULL, SQL_IS_POINTER)) ? SUCCEED : FAIL;
215 struct tdsodbc_impl_bcp_batch_params
220 static TDSODBC_INLINE
int
223 struct tdsodbc_impl_bcp_batch_params params = {-1};
224 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_BATCH, ¶ms, SQL_IS_POINTER)) ? params.rows : -1;
227 struct tdsodbc_impl_bcp_done_params
232 static TDSODBC_INLINE
int
235 struct tdsodbc_impl_bcp_done_params params = {-1};
236 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_DONE, ¶ms, SQL_IS_POINTER)) ? params.rows : -1;
239 struct tdsodbc_impl_bcp_bind_params
241 const BYTE * varaddr;
244 const BYTE * terminator;
250 static TDSODBC_INLINE RETCODE
251 bcp_bind(HDBC hdbc,
const BYTE * varaddr,
int prefixlen,
int varlen,
252 const BYTE * terminator,
int termlen,
int vartype,
int table_column)
254 struct tdsodbc_impl_bcp_bind_params params = {varaddr, prefixlen, varlen, terminator, termlen, vartype, table_column};
255 return SQL_SUCCEEDED(SQLSetConnectAttr(hdbc, SQL_COPT_TDSODBC_IMPL_BCP_BIND, ¶ms, SQL_IS_POINTER)) ? SUCCEED : FAIL;
259 #define bcp_init bcp_initW
261 #define bcp_init bcp_initA
DBINT bcp_batch(DBPROCESS *dbproc)
Commit a set of rows to the table.
Definition: bcp.c:1939
RETCODE bcp_control(DBPROCESS *dbproc, int field, DBINT value)
Set BCP options for uploading a datafile.
Definition: bcp.c:535
RETCODE bcp_bind(DBPROCESS *dbproc, BYTE *varaddr, int prefixlen, DBINT varlen, BYTE *terminator, int termlen, int vartype, int table_column)
Bind a program host variable to a database column.
Definition: bcp.c:2008
RETCODE bcp_colptr(DBPROCESS *dbproc, BYTE *colptr, int table_column)
Override bcp_bind() by pointing to a different host variable.
Definition: bcp.c:657
DBINT bcp_done(DBPROCESS *dbproc)
Conclude the transfer of data from program variables.
Definition: bcp.c:1966
RETCODE bcp_sendrow(DBPROCESS *dbproc)
Write data in host variables to the table.
Definition: bcp.c:1326