FreeTDS API
Loading...
Searching...
No Matches
sybdb.h
Go to the documentation of this file.
1/* FreeTDS - Library of routines accessing Sybase and Microsoft databases
2 * Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004 Brian Bruns
3 * Copyright (C) 2010, 2011 Frediano Ziglio
4 *
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
9 *
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Library General Public License for more details.
14 *
15 * You should have received a copy of the GNU Library General Public
16 * License along with this library; if not, write to the
17 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 * Boston, MA 02111-1307, USA.
19 */
20
28#ifndef _sybdb_h_
29#define _sybdb_h_
30
31#include "tds_sysdep_public.h"
32
33#undef TDS_STATIC_CAST
34#ifdef __cplusplus
35#define TDS_STATIC_CAST(type, a) static_cast<type>(a)
36extern "C"
37{
38#if 0
39}
40#endif
41#else
42#define TDS_STATIC_CAST(type, a) ((type)(a))
43#endif
44
45#ifdef FALSE
46#undef FALSE
47#endif
48#ifdef TRUE
49#undef TRUE
50#endif
51#define FALSE 0
52#define TRUE 1
53
54#define DBSAVE 1
55#define DBNOSAVE 0
56#define DBNOERR -1
57
58#define INT_EXIT 0
59#define INT_CONTINUE 1
60#define INT_CANCEL 2
61#define INT_TIMEOUT 3
62
63#define DBMAXNUMLEN 33
64/* https://msdn.microsoft.com/en-us/library/ms176061.aspx */
65#define DBMAXNAME 128
66
70#define DBVERSION_UNKNOWN 0
71#define DBVERSION_46 1
72#define DBVERSION_100 2
73#define DBVERSION_42 3
74#define DBVERSION_70 4
75#define DBVERSION_71 5
76#define DBVERSION_72 6
77#define DBVERSION_73 7
78#define DBVERSION_74 8
79
80/* these two are defined by Microsoft for dbsetlversion() */
81#define DBVER42 DBVERSION_42
82#define DBVER60 DBVERSION_70 /* our best approximation */
83
88#define DBTDS_UNKNOWN 0
89#define DBTDS_2_0 1 /* pre 4.0 SQL Server */
90#define DBTDS_3_4 2 /* Microsoft SQL Server (3.0) */
91#define DBTDS_4_0 3 /* 4.0 SQL Server */
92#define DBTDS_4_2 4 /* 4.2 SQL Server */
93#define DBTDS_4_6 5 /* 2.0 OpenServer and 4.6 SQL Server. */
94#define DBTDS_4_9_5 6 /* 4.9.5 (NCR) SQL Server */
95#define DBTDS_5_0 7 /* 5.0 SQL Server */
96#define DBTDS_7_0 8 /* Microsoft SQL Server 7.0 */
97#define DBTDS_8_0 ("Use DBTDS_7_1 instead"*x) /* Microsoft SQL Server 2000 */
98#define DBTDS_9_0 ("Use DBTDS_7_2 instead"*x) /* Microsoft SQL Server 2005 */
99#define DBTDS_7_1 9 /* Microsoft SQL Server 2000 */
100#define DBTDS_7_2 10 /* Microsoft SQL Server 2005 */
101#define DBTDS_7_3 11 /* Microsoft SQL Server 2008 */
102#define DBTDS_7_4 12 /* Microsoft SQL Server 2012/2014 */
103#define DBTDS_8_0_ 13 /* Microsoft SQL Server 2022 */
104
105#define DBTXPLEN 16
106
107#define BCPMAXERRS 1
108#define BCPFIRST 2
109#define BCPLAST 3
110#define BCPBATCH 4
111#define BCPKEEPIDENTITY 8
112
113#define BCPLABELED 5
114#define BCPHINTS 6
115
116#define DBCMDNONE 0
117#define DBCMDPEND 1
118#define DBCMDSENT 2
119
120typedef int RETCODE;
121
122typedef void DBCURSOR;
123typedef void DBXLATE;
124typedef void DBSORTORDER;
125typedef void DBLOGINFO;
126typedef void *DBVOIDPTR;
127typedef short SHORT;
128typedef unsigned short USHORT;
129typedef int (*INTFUNCPTR) (void *, ...);
130typedef int (*DBWAITFUNC) (void);
131typedef DBWAITFUNC(*DB_DBBUSY_FUNC) (void *dbproc);
132typedef void (*DB_DBIDLE_FUNC) (DBWAITFUNC dfunc, void *dbproc);
133typedef int (*DB_DBCHKINTR_FUNC) (void *dbproc);
134typedef int (*DB_DBHNDLINTR_FUNC) (void *dbproc);
135
136#ifndef __INCvxWorksh
137/* VxWorks already defines STATUS and BOOL. Compiler gets mad if you
138** redefine them. */
139/* __INCvxWorksh will get #defined by std. include files included from tds.h
140*/
141#ifdef STATUS
142/* On DU4.0d we get a conflicting STATUS definition from arpa/nameser.h
143 when _REENTRANT is defined.
144*/
145#undef STATUS
146#endif
147typedef int STATUS;
148#if !defined(_WINDEF_) && !defined(_WINDEF_H) && !defined(DOS32X)
149typedef int BOOL;
150#endif
151#endif
152
153#ifndef _tdsguard_hfOrWb5znoUCWdBPoNQvqN_
154/* copied from tds.h */
155/* TODO find a best way... */
156enum
157{
158 SYBCHAR = 47, /* 0x2F */
159#define SYBCHAR SYBCHAR
160 SYBVARCHAR = 39, /* 0x27 */
161#define SYBVARCHAR SYBVARCHAR
162 SYBINTN = 38, /* 0x26 */
163#define SYBINTN SYBINTN
164 SYBINT1 = 48, /* 0x30 */
165#define SYBINT1 SYBINT1
166 SYBINT2 = 52, /* 0x34 */
167#define SYBINT2 SYBINT2
168 SYBINT4 = 56, /* 0x38 */
169#define SYBINT4 SYBINT4
170 SYBINT8 = 127, /* 0x7F */
171#define SYBINT8 SYBINT8
172 SYBFLT8 = 62, /* 0x3E */
173#define SYBFLT8 SYBFLT8
174 SYBDATETIME = 61, /* 0x3D */
175#define SYBDATETIME SYBDATETIME
176 SYBBIT = 50, /* 0x32 */
177#define SYBBIT SYBBIT
178 SYBBITN = 104, /* 0x68 */
179#define SYBBITN SYBBITN
180 SYBTEXT = 35, /* 0x23 */
181#define SYBTEXT SYBTEXT
182 SYBNTEXT = 99, /* 0x63 */
183#define SYBNTEXT SYBNTEXT
184 SYBIMAGE = 34, /* 0x22 */
185#define SYBIMAGE SYBIMAGE
186 SYBMONEY4 = 122, /* 0x7A */
187#define SYBMONEY4 SYBMONEY4
188 SYBMONEY = 60, /* 0x3C */
189#define SYBMONEY SYBMONEY
190 SYBDATETIME4 = 58, /* 0x3A */
191#define SYBDATETIME4 SYBDATETIME4
192 SYBREAL = 59, /* 0x3B */
193#define SYBREAL SYBREAL
194 SYBBINARY = 45, /* 0x2D */
195#define SYBBINARY SYBBINARY
196 SYBVOID = 31, /* 0x1F */
197#define SYBVOID SYBVOID
198 SYBVARBINARY = 37, /* 0x25 */
199#define SYBVARBINARY SYBVARBINARY
200 SYBNUMERIC = 108, /* 0x6C */
201#define SYBNUMERIC SYBNUMERIC
202 SYBDECIMAL = 106, /* 0x6A */
203#define SYBDECIMAL SYBDECIMAL
204 SYBFLTN = 109, /* 0x6D */
205#define SYBFLTN SYBFLTN
206 SYBMONEYN = 110, /* 0x6E */
207#define SYBMONEYN SYBMONEYN
208 SYBDATETIMN = 111, /* 0x6F */
209#define SYBDATETIMN SYBDATETIMN
210 SYBNVARCHAR = 103, /* 0x67 */
211#define SYBNVARCHAR SYBNVARCHAR
212 SYBDATE = 49, /* 0x31 */
213#define SYBDATE SYBDATE
214 SYBTIME = 51, /* 0x33 */
215#define SYBTIME SYBTIME
216 SYBBIGDATETIME = 187, /* 0xBB */
217#define SYBBIGDATETIME SYBBIGDATETIME
218 SYBBIGTIME = 188, /* 0xBC */
219#define SYBBIGTIME SYBBIGTIME
220 SYBMSDATE = 40, /* 0x28 */
221#define SYBMSDATE SYBMSDATE
222 SYBMSTIME = 41, /* 0x29 */
223#define SYBMSTIME SYBMSTIME
224 SYBMSDATETIME2 = 42, /* 0x2A */
225#define SYBMSDATETIME2 SYBMSDATETIME2
226 SYBMSDATETIMEOFFSET = 43, /* 0x2B */
227#define SYBMSDATETIMEOFFSET SYBMSDATETIMEOFFSET
228};
229
230#define SYBAOPCNT 0x4b
231#define SYBAOPCNTU 0x4c
232#define SYBAOPSUM 0x4d
233#define SYBAOPSUMU 0x4e
234#define SYBAOPAVG 0x4f
235#define SYBAOPAVGU 0x50
236#define SYBAOPMIN 0x51
237#define SYBAOPMAX 0x52
238
239/* mssql2k compute operator */
240#define SYBAOPCNT_BIG 0x09
241#define SYBAOPSTDEV 0x30
242#define SYBAOPSTDEVP 0x31
243#define SYBAOPVAR 0x32
244#define SYBAOPVARP 0x33
245#define SYBAOPCHECKSUM_AGG 0x72
246
247#endif
248
249typedef unsigned char DBBOOL;
250typedef char DBCHAR;
251typedef unsigned char DBBIT;
252typedef unsigned char DBTINYINT;
253typedef int16_t DBSMALLINT;
254typedef int32_t DBINT;
255typedef int64_t DBBIGINT;
256typedef unsigned char DBBINARY;
257typedef tds_sysdep_real32_type DBREAL;
258typedef tds_sysdep_real64_type DBFLT8;
259typedef uint16_t DBUSMALLINT;
260typedef uint32_t DBUINT;
261typedef uint64_t DBUBIGINT;
262
263typedef struct
264{
265 DBSMALLINT len;
266 char str[256];
267} DBVARYCHAR;
268
269typedef struct
270{
271 DBSMALLINT len;
272 unsigned char array[256];
273} DBVARYBIN;
274
275typedef struct
276{
277 unsigned char precision;
278 unsigned char scale;
279 unsigned char array[33];
280} DBNUMERIC;
281
282typedef DBNUMERIC DBDECIMAL;
283
284typedef struct
285{
286 DBINT mnyhigh;
287 DBUINT mnylow;
288} DBMONEY;
289
290typedef struct
291{
292 DBINT mny4;
293} DBMONEY4;
294
295typedef struct
296{
297 DBINT dtdays;
298 DBINT dttime;
299} DBDATETIME;
300
301typedef struct
302{
303 DBUSMALLINT days; /* days since Jan-1-1900 */
304 DBUSMALLINT minutes; /* minutes since midnight */
306
307typedef struct
308{
309 DBUBIGINT time;
310 DBINT date;
311 DBSMALLINT offset;
312 DBUSMALLINT time_prec:3;
313/* fix a problem with some public headers defining _res */
314#undef _res
315 DBUSMALLINT _res:10;
316 DBUSMALLINT has_time:1;
317 DBUSMALLINT has_date:1;
318 DBUSMALLINT has_offset:1;
320
321#ifdef MSDBLIB
322# define SQLCHAR SYBCHAR
323 typedef struct
324 {
325 DBUSMALLINT numdays;
326 DBUSMALLINT nummins;
327 } DBDATETIM4;
328#endif
329
330typedef struct tds_dblib_loginrec LOGINREC;
331
332#ifndef DOS32X
333typedef unsigned char BYTE;
334#endif
335
336typedef struct dbtypeinfo
337{
338 DBINT precision;
339 DBINT scale;
340} DBTYPEINFO;
341
343{
344 BYTE *strtext;
345 DBINT strtotlen;
346 struct dbstring *strnext;
347};
348typedef struct dbstring DBSTRING;
349
350/* Used by dbcolinfo */
351enum
352{ MAXCOLNAMELEN = 512 }; /* duplicates TDS_SYSNAME_SIZE */
353typedef enum { CI_REGULAR=1, CI_ALTERNATE=2, CI_CURSOR=3 } CI_TYPE;
354
355typedef struct
356{
357 DBINT SizeOfStruct;
358 DBCHAR Name[MAXCOLNAMELEN+2];
359 DBCHAR ActualName[MAXCOLNAMELEN+2];
360 DBCHAR TableName[MAXCOLNAMELEN+2];
361 SHORT Type;
362 DBINT UserType;
363 DBINT MaxLength;
364 BYTE Precision;
365 BYTE Scale;
366 BOOL VarLength;
367 BYTE Null;
368 BYTE CaseSensitive;
369 BYTE Updatable;
370 BOOL Identity;
371
372} DBCOL;
373
374typedef struct
375{
376 DBINT SizeOfStruct;
377 DBCHAR Name[MAXCOLNAMELEN+2];
378 DBCHAR ActualName[MAXCOLNAMELEN+2];
379 DBCHAR TableName[MAXCOLNAMELEN+2];
380 SHORT Type;
381 DBINT UserType;
382 DBINT MaxLength;
383 BYTE Precision;
384 BYTE Scale;
385 BOOL VarLength;
386 BYTE Null;
387 BYTE CaseSensitive;
388 BYTE Updatable;
389 BOOL Identity;
390 SHORT ServerType;
391 DBINT ServerMaxLength;
392 DBCHAR ServerTypeDeclaration[256];
393} DBCOL2;
394/* end dbcolinfo stuff */
395
396
397
398/* a large list of options, DBTEXTSIZE is needed by sybtcl */
399#define DBPARSEONLY 0
400#define DBESTIMATE 1
401#define DBSHOWPLAN 2
402#define DBNOEXEC 3
403#define DBARITHIGNORE 4
404#define DBNOCOUNT 5
405#define DBARITHABORT 6
406#define DBTEXTLIMIT 7
407#define DBBROWSE 8
408#define DBOFFSET 9
409#define DBSTAT 10
410#define DBERRLVL 11
411#define DBCONFIRM 12
412#define DBSTORPROCID 13
413#define DBBUFFER 14
414#define DBNOAUTOFREE 15
415#define DBROWCOUNT 16
416#define DBTEXTSIZE 17
417#define DBNATLANG 18
418#define DBDATEFORMAT 19
419#define DBPRPAD 20
420#define DBPRCOLSEP 21
421#define DBPRLINELEN 22
422#define DBPRLINESEP 23
423#define DBLFCONVERT 24
424#define DBDATEFIRST 25
425#define DBCHAINXACTS 26
426#define DBFIPSFLAG 27
427#define DBISOLATION 28
428#define DBAUTH 29
429#define DBIDENTITY 30
430#define DBNOIDCOL 31
431#define DBDATESHORT 32
432#define DBCLIENTCURSORS 33
433#define DBSETTIME 34
434#define DBQUOTEDIDENT 35
435
436#define DBNUMOPTIONS 36
437
438#define DBPADOFF 0
439#define DBPADON 1
440
441#define OFF 0
442#define ON 1
443
444#define NOSUCHOPTION 2
445
446#define MAXOPTTEXT 32
447
448typedef struct tds_dblib_dbprocess DBPROCESS;
449
450/*
451 * Sybase & Microsoft use different names for the dbdaterec members.
452 * Keep these two structures physically identical in memory.
453 * dbdatecrack() casts one to the other for ease of implementation.
454 *
455 * Giving credit where credit is due, we can acknowledge that
456 * Microsoft chose the better names here, hands down. ("datedmonth"?!)
457 */
459{
460 DBINT year; /* 1753 - 9999 */
461 DBINT quarter; /* 1 - 4 */
462 DBINT month; /* 1 - 12 */
463 DBINT day; /* 1 - 31 */
464 DBINT dayofyear; /* 1 - 366 */
465 DBINT week; /* 1 - 54 (for leap years) */
466 DBINT weekday; /* 1 - 7 (Mon. - Sun.) */
467 DBINT hour; /* 0 - 23 */
468 DBINT minute; /* 0 - 59 */
469 DBINT second; /* 0 - 59 */
470 DBINT millisecond; /* 0 - 999 */
471 DBINT tzone; /* -840 - 840 */
472};
473
475{
476 DBINT dateyear; /* 1900 and counting */
477 DBINT quarter; /* 0 - 3 (Microsoft only) */
478 DBINT datemonth; /* 0 - 11 */
479 DBINT datedmonth; /* 1 - 31 */
480 DBINT datedyear; /* 1 - 366 */
481 DBINT week; /* 1 - 54 (Microsoft only) */
482 DBINT datedweek; /* 0 - 6 */
483 DBINT datehour; /* 0 - 23 */
484 DBINT dateminute; /* 0 - 59 */
485 DBINT datesecond; /* 0 - 59 */
486 DBINT datemsecond; /* 0 - 999 */
487 DBINT datetzone; /* -840 - 840 */
488};
489
491{
492 DBINT year; /* 1753 - 9999 */
493 DBINT quarter; /* 1 - 4 */
494 DBINT month; /* 1 - 12 */
495 DBINT day; /* 1 - 31 */
496 DBINT dayofyear; /* 1 - 366 */
497 DBINT week; /* 1 - 54 (for leap years) */
498 DBINT weekday; /* 1 - 7 (Mon. - Sun.) */
499 DBINT hour; /* 0 - 23 */
500 DBINT minute; /* 0 - 59 */
501 DBINT second; /* 0 - 59 */
502 DBINT nanosecond; /* 0 - 999999999 */
503 DBINT tzone; /* 0 - 127 (Sybase only) */
504};
505
507{
508 DBINT dateyear; /* 1900 and counting */
509 DBINT quarter; /* 0 - 3 (Microsoft only) */
510 DBINT datemonth; /* 0 - 11 */
511 DBINT datedmonth; /* 1 - 31 */
512 DBINT datedyear; /* 1 - 366 */
513 DBINT week; /* 1 - 54 (Microsoft only) */
514 DBINT datedweek; /* 0 - 6 */
515 DBINT datehour; /* 0 - 23 */
516 DBINT dateminute; /* 0 - 59 */
517 DBINT datesecond; /* 0 - 59 */
518 DBINT datensecond; /* 0 - 999999999 */
519 DBINT datetzone; /* 0 - 127 */
520};
521
522
523#ifdef MSDBLIB
526#else
527typedef struct tds_sybase_dbdaterec DBDATEREC;
528typedef struct tds_sybase_dbdaterec2 DBDATEREC2;
529#endif
530
531typedef int (*EHANDLEFUNC) (DBPROCESS * dbproc, int severity, int dberr, int oserr, char *dberrstr, char *oserrstr);
532
533typedef int (*MHANDLEFUNC) (DBPROCESS * dbproc, DBINT msgno, int msgstate, int severity, char *msgtext, char *srvname,
534 char *proc, int line);
535
536/* dbpoll() result codes, sybtcl needs DBRESULT */
537#define DBRESULT 1
538#define DBNOTIFICATION 2
539#define DBTIMEOUT 3
540#define DBINTERRUPT 4
541
542/* more sybtcl needs: */
543#define DBTXTSLEN 8
544
545/* bind types */
546#define CHARBIND 0
547#define STRINGBIND 1
548#define NTBSTRINGBIND 2
549#define VARYCHARBIND 3
550#define VARYBINBIND 4
551#define TINYBIND 6
552#define SMALLBIND 7
553#define INTBIND 8
554#define FLT8BIND 9
555#define REALBIND 10
556#define DATETIMEBIND 11
557#define SMALLDATETIMEBIND 12
558#define MONEYBIND 13
559#define SMALLMONEYBIND 14
560#define BINARYBIND 15
561#define BITBIND 16
562#define NUMERICBIND 17
563#define DECIMALBIND 18
564#define SRCNUMERICBIND 19
565#define SRCDECIMALBIND 20
566#define DATEBIND 21
567#define TIMEBIND 22
568#define BIGDATETIMEBIND 23
569#define BIGTIMEBIND 24
570#define BIGINTBIND 30
571#define DATETIME2BIND 31
572#define MAXBINDTYPES 32 /* keep last */
573
574#define DBPRCOLSEP 21
575#define DBPRLINELEN 22
576#define DBRPCNORETURN 0
577#define DBRPCRETURN 1
578#define DBRPCDEFAULT 2
579
580#define REG_ROW -1
581#define MORE_ROWS -1
582#define NO_MORE_ROWS -2
583#define BUF_FULL -3
584#define NO_MORE_RESULTS 2
585#define SUCCEED 1
586#define FAIL 0
587
588#define DB_IN 1
589#define DB_OUT 2
590#define DB_QUERYOUT 3
591
592#define DBSINGLE 0
593#define DBDOUBLE 1
594#define DBBOTH 2
595
596/* remote procedure call (rpc) options */
597#define DBRPCRECOMPILE TDS_STATIC_CAST(DBSMALLINT, 0x0001)
598#define DBRPCRESET TDS_STATIC_CAST(DBSMALLINT, 0x0002)
599#define DBRPCCURSOR TDS_STATIC_CAST(DBSMALLINT, 0x0008)
600
601#if defined(DBLIB_UNIMPLEMENTED)
602DBBOOL db12hour(DBPROCESS * dbprocess, const char language[]);
603
604DBBOOL dbcolbrowse(DBPROCESS * dbprocess, int colnum);
605
606RETCODE dbcursor(DBCURSOR * hc, DBINT optype, DBINT bufno, BYTE * table, BYTE * values);
607RETCODE dbcursorbind(DBCURSOR * hc, int col, int vartype, DBINT varlen, DBINT * poutlen, BYTE * pvaraddr, DBTYPEINFO * typeinfo);
608void dbcursorclose(DBCURSOR * hc);
609RETCODE dbcursorcolinfo(DBCURSOR * hc, DBINT column, DBCHAR * colname, DBINT * coltype, DBINT * collen, DBINT * usertype);
610RETCODE dbcursorfetch(DBCURSOR * hc, DBINT fetchtype, DBINT rownum);
611RETCODE dbcursorinfo(DBCURSOR * hc, DBINT * ncols, DBINT * nrows);
612DBCURSOR *dbcursoropen(DBPROCESS * dbprocess, BYTE * stmt, SHORT scollopt, SHORT concuropt, USHORT nrows, DBINT * pstatus);
613
614int dbdate4cmp(DBPROCESS * dbprocess, DBDATETIME4 * d1, DBDATETIME4 * d2);
615RETCODE dbdate4zero(DBPROCESS * dbprocess, DBDATETIME4 * d1);
616RETCODE dbdatechar(DBPROCESS * dbprocess, char *buf, int datepart, int value);
617int dbdatename(DBPROCESS * dbprocess, char *buf, int date, DBDATETIME * datetime);
618char *dateorder(DBPROCESS * dbprocess, char *language);
619DBINT dbdatepart(DBPROCESS * dbprocess, int datepart, DBDATETIME * datetime);
620RETCODE dbdatezero(DBPROCESS * dbprocess, DBDATETIME * d1);
621char *dbdayname(DBPROCESS * dbprocess, char *language, int daynum);
622
623int dbgetoff(DBPROCESS * dbprocess, DBUSMALLINT offtype, int startfrom);
624
625char *dbqual(DBPROCESS * dbprocess, int tabnum, char *tabname);
626void dbfreequal(char *qualptr);
627
628DBSORTORDER *dbloadsort(DBPROCESS * dbprocess);
629RETCODE dbfreesort(DBPROCESS * dbprocess, DBSORTORDER * sortorder);
630
631RETCODE dbload_xlate(DBPROCESS * dbprocess, char *srv_charset, char *clt_name, DBXLATE ** xlt_tosrv, DBXLATE ** xlt_todisp);
632
633RETCODE dbmny4divide(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * quotient);
634RETCODE dbmny4mul(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * prod);
635RETCODE dbmnyadd(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * sum);
636RETCODE dbmnydivide(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * quotient);
637RETCODE dbmnydown(DBPROCESS * dbproc, DBMONEY * mnyptr, int divisor, int *remainder);
638RETCODE dbmnyinit(DBPROCESS * dbproc, DBMONEY * mnyptr, int trim, DBBOOL * negative);
639RETCODE dbmnyndigit(DBPROCESS * dbproc, DBMONEY * mnyptr, DBCHAR * value, DBBOOL * zero);
640RETCODE dbmnymul(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * prod);
641RETCODE dbmnydigit(DBPROCESS * dbprocess, DBMONEY * m1, DBCHAR * value, DBBOOL * zero);
642RETCODE dbmnyscale(DBPROCESS * dbproc, DBMONEY * dest, int multiplier, int addend);
643
644
645RETCODE dbnpcreate(DBPROCESS * dbprocess);
646RETCODE dbnpdefine(DBPROCESS * dbprocess, DBCHAR * procedure_name, DBSMALLINT namelen);
647
648int DBNUMORDERS(DBPROCESS * dbprocess);
649
650RETCODE dbpoll(DBPROCESS * dbproc, long milliseconds, DBPROCESS ** ready_dbproc, int *return_reason);
651int dbordercol(DBPROCESS * dbprocess, int order);
652
653RETCODE dbregdrop(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen);
654RETCODE dbregexec(DBPROCESS * dbproc, DBUSMALLINT options);
655RETCODE dbreghandle(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen, INTFUNCPTR handler);
656RETCODE dbreginit(DBPROCESS * dbproc, DBCHAR * procedure_name, DBSMALLINT namelen);
657RETCODE dbreglist(DBPROCESS * dbproc);
658RETCODE dbregnowatch(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen);
659RETCODE dbregparam(DBPROCESS * dbproc, char *param_name, int type, DBINT datalen, BYTE * data);
660RETCODE dbregwatch(DBPROCESS * dbprocess, DBCHAR * procnm, DBSMALLINT namelen, DBUSMALLINT options);
661RETCODE dbregwatchlist(DBPROCESS * dbprocess);
662
663void dbrpwclr(LOGINREC * login);
664RETCODE dbrpwset(LOGINREC * login, char *srvname, char *password, int pwlen);
665
666DBINT dbreadpage(DBPROCESS * dbprocess, char *p_dbname, DBINT pageno, BYTE * buf);
667RETCODE dbwritepage(DBPROCESS * dbprocess, char *p_dbname, DBINT pageno, DBINT size, BYTE * buf);
668
669RETCODE dbsetdeflang(char *language);
670
671int dbstrcmp(DBPROCESS * dbprocess, char *s1, int l1, char *s2, int l2, DBSORTORDER * sort);
672int dbstrsort(DBPROCESS * dbprocess, char *s1, int l1, char *s2, int l2, DBSORTORDER * sort);
673
674DBBOOL dbtabbrowse(DBPROCESS * dbprocess, int tabnum);
675int dbtabcount(DBPROCESS * dbprocess);
676char *dbtabname(DBPROCESS * dbprocess, int tabnum);
677char *dbtabsource(DBPROCESS * dbprocess, int colnum, int *tabnum);
678
679RETCODE dbsendpassthru(DBPROCESS * dbprocess, DBVOIDPTR bufp);
680RETCODE dbrecvpassthru(DBPROCESS * dbprocess, DBVOIDPTR * bufp);
681
682RETCODE dbgetloginfo(DBPROCESS * dbprocess, DBLOGINFO ** loginfo);
683RETCODE dbsetloginfo(LOGINREC * loginrec, DBLOGINFO * loginfo);
684
685int dbtsnewlen(DBPROCESS * dbprocess);
686DBBINARY *dbtsnewval(DBPROCESS * dbprocess);
687RETCODE dbtsput(DBPROCESS * dbprocess, DBBINARY * newts, int newtslen, int tabnum, char *tabname);
688
689RETCODE dbfree_xlate(DBPROCESS * dbprocess, DBXLATE * xlt_tosrv, DBXLATE * clt_todisp);
690int dbxlate(DBPROCESS * dbprocess, char *src, int srclen, char *dest, int destlen, DBXLATE * xlt, int *srcbytes_used,
691 DBBOOL srcend, int status);
692
693RETCODE bcp_moretext(DBPROCESS * dbproc, DBINT size, BYTE * text);
694RETCODE bcp_writefmt(DBPROCESS * dbproc, const char filename[]);
695
696void build_xact_string(char *xact_name, char *service_name, DBINT commid, char *result);
697RETCODE remove_xact(DBPROCESS * connect, DBINT commid, int n);
698RETCODE abort_xact(DBPROCESS * connect, DBINT commid);
699void close_commit(DBPROCESS * connect);
700RETCODE commit_xact(DBPROCESS * connect, DBINT commid);
701DBPROCESS *open_commit(LOGINREC * login, char *servername);
702RETCODE scan_xact(DBPROCESS * connect, DBINT commid);
703DBINT start_xact(DBPROCESS * connect, char *application_name, char *xact_name, int site_count);
704DBINT stat_xact(DBPROCESS * connect, DBINT commid);
705
706#endif /* define unimplemented */
707
708BYTE *dbadata(DBPROCESS * dbproc, int computeid, int column);
709DBINT dbadlen(DBPROCESS * dbproc, int computeid, int column);
710RETCODE dbaltbind(DBPROCESS * dbprocess, int computeid, int column, int vartype, DBINT varlen, BYTE * varaddr);
711RETCODE dbaltbind_ps(DBPROCESS * dbprocess, int computeid, int column, int vartype, DBINT varlen, BYTE * varaddr,
712 DBTYPEINFO * typeinfo);
713int dbaltcolid(DBPROCESS * dbproc, int computeid, int column);
714DBINT dbaltlen(DBPROCESS * dbproc, int computeid, int column);
715int dbaltop(DBPROCESS * dbproc, int computeid, int column);
716int dbalttype(DBPROCESS * dbproc, int computeid, int column);
717DBINT dbaltutype(DBPROCESS * dbproc, int computeid, int column);
718RETCODE dbanullbind(DBPROCESS * dbprocess, int computeid, int column, DBINT * indicator);
719RETCODE dbbind(DBPROCESS * dbproc, int column, int vartype, DBINT varlen, BYTE * varaddr);
720RETCODE dbbind_ps(DBPROCESS * dbprocess, int column, int vartype, DBINT varlen, BYTE * varaddr, DBTYPEINFO * typeinfo);
721int dbbufsize(DBPROCESS * dbprocess);
722BYTE *dbbylist(DBPROCESS * dbproc, int computeid, int *size);
723RETCODE dbcancel(DBPROCESS * dbproc);
724RETCODE dbcanquery(DBPROCESS * dbproc);
725char *dbchange(DBPROCESS * dbprocess);
726DBBOOL dbcharsetconv(DBPROCESS * dbprocess);
727void dbclose(DBPROCESS * dbproc);
728void dbclrbuf(DBPROCESS * dbproc, DBINT n);
729RETCODE dbclropt(DBPROCESS * dbproc, int option, const char param[]);
730RETCODE dbcmd(DBPROCESS * dbproc, const char cmdstring[]);
731RETCODE dbcmdrow(DBPROCESS * dbproc);
732
733#define DBCMDROW(x) dbcmdrow((x))
734RETCODE dbtablecolinfo (DBPROCESS *dbproc, DBINT column, DBCOL *pdbcol );
735RETCODE dbcolinfo (DBPROCESS *dbproc, CI_TYPE type, DBINT column, DBINT computeid, DBCOL *pdbcol);
736DBINT dbcollen(DBPROCESS * dbproc, int column);
737char *dbcolname(DBPROCESS * dbproc, int column);
738const char *dbacolname(DBPROCESS * dbproc, int computeid, int column);
739char *dbcolsource(DBPROCESS * dbproc, int colnum);
740int dbcoltype(DBPROCESS * dbproc, int column);
741DBTYPEINFO *dbcoltypeinfo(DBPROCESS * dbproc, int column);
742DBINT dbcolutype(DBPROCESS * dbprocess, int column);
743DBINT dbconvert(DBPROCESS * dbproc, int srctype, const BYTE * src, DBINT srclen, int desttype, BYTE * dest, DBINT destlen);
744DBINT dbconvert_ps(DBPROCESS * dbprocess, int srctype, const BYTE * src, DBINT srclen, int desttype, BYTE * dest, DBINT destlen,
745 DBTYPEINFO * typeinfo);
746BOOL dbiscount(DBPROCESS * dbproc);
747DBINT dbcount(DBPROCESS * dbproc);
748
749#define DBCOUNT(x) dbcount((x))
750int dbcurcmd(DBPROCESS * dbproc);
751
752#define DBCURCMD(x) dbcurcmd((x))
753DBINT dbcurrow(DBPROCESS * dbproc);
754
755#define DBCURROW(x) dbcurrow((x))
756BYTE *dbdata(DBPROCESS * dbproc, int column);
757int dbdatecmp(DBPROCESS * dbproc, DBDATETIME * d1, DBDATETIME * d2);
758RETCODE dbdatecrack(DBPROCESS * dbproc, DBDATEREC * di, DBDATETIME * dt);
759RETCODE dbanydatecrack(DBPROCESS * dbproc, DBDATEREC2 * di, int type, const void *data);
760DBINT dbdatlen(DBPROCESS * dbproc, int column);
761DBBOOL dbdead(DBPROCESS * dbproc);
762
763#define DBDEAD(x) dbdead((x))
764EHANDLEFUNC dberrhandle(EHANDLEFUNC handler);
765void dbexit(void);
766RETCODE dbfcmd(DBPROCESS * dbproc, const char *fmt, ...);
767DBINT dbfirstrow(DBPROCESS * dbproc);
768
769#define DBFIRSTROW(x) dbfirstrow((x))
770void dbfreebuf(DBPROCESS * dbproc);
771char *dbgetchar(DBPROCESS * dbprocess, int n);
772char *dbgetcharset(DBPROCESS * dbprocess);
773int dbgetlusername(LOGINREC * login, BYTE * name_buffer, int buffer_len);
774int dbgetmaxprocs(void);
775char *dbgetnatlanf(DBPROCESS * dbprocess);
776int dbgetpacket(DBPROCESS * dbproc);
777RETCODE dbgetrow(DBPROCESS * dbproc, DBINT row);
778int dbgettime(void);
779#define DBGETTIME dbgettime
780BYTE *dbgetuserdata(DBPROCESS * dbproc);
781DBBOOL dbhasretstat(DBPROCESS * dbproc);
782RETCODE dbinit(void);
783int dbiordesc(DBPROCESS * dbproc);
784
785#define DBIORDESC(x) dbiordesc((x))
786int dbiowdesc(DBPROCESS * dbproc);
787
788#define DBIOWDESC(x) dbiowdesc((x))
789DBBOOL dbisavail(DBPROCESS * dbprocess);
790
791#define DBISAVAIL(x) dbisavail((x))
792DBBOOL dbisopt(DBPROCESS * dbproc, int option, const char param[]);
793DBINT dblastrow(DBPROCESS * dbproc);
794
795#define DBLASTROW(x) dblastrow((x))
796LOGINREC *dblogin(void);
797void dbloginfree(LOGINREC * login);
798
799int dbmny4cmp(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2);
800int dbmnycmp(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2);
801
802RETCODE dbmny4add(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * sum);
803RETCODE dbmnydec(DBPROCESS * dbproc, DBMONEY * mnyptr);
804RETCODE dbmnyinc(DBPROCESS * dbproc, DBMONEY * mnyptr);
805RETCODE dbmnymaxpos(DBPROCESS * dbproc, DBMONEY * dest);
806RETCODE dbmnymaxneg(DBPROCESS * dbproc, DBMONEY * dest);
807RETCODE dbmny4minus(DBPROCESS * dbproc, DBMONEY4 * src, DBMONEY4 * dest);
808RETCODE dbmnyminus(DBPROCESS * dbproc, DBMONEY * src, DBMONEY * dest);
809RETCODE dbmny4sub(DBPROCESS * dbproc, DBMONEY4 * m1, DBMONEY4 * m2, DBMONEY4 * diff);
810RETCODE dbmnysub(DBPROCESS * dbproc, DBMONEY * m1, DBMONEY * m2, DBMONEY * diff);
811
812RETCODE dbmny4copy(DBPROCESS * dbprocess, DBMONEY4 * m1, DBMONEY4 * m2);
813RETCODE dbmnycopy(DBPROCESS * dbproc, DBMONEY * src, DBMONEY * dest);
814
815RETCODE dbmny4zero(DBPROCESS * dbproc, DBMONEY4 * dest);
816RETCODE dbmnyzero(DBPROCESS * dbproc, DBMONEY * dest);
817
818const char *dbmonthname(DBPROCESS * dbproc, char *language, int monthnum, DBBOOL shortform);
819RETCODE dbmorecmds(DBPROCESS * dbproc);
820
821#define DBMORECMDS(x) dbmorecmds((x))
822RETCODE dbmoretext(DBPROCESS * dbproc, DBINT size, const BYTE text[]);
823MHANDLEFUNC dbmsghandle(MHANDLEFUNC handler);
824char *dbname(DBPROCESS * dbproc);
825STATUS dbnextrow(DBPROCESS * dbproc);
826RETCODE dbnullbind(DBPROCESS * dbproc, int column, DBINT * indicator);
827int dbnumalts(DBPROCESS * dbproc, int computeid);
828int dbnumcols(DBPROCESS * dbproc);
829int dbnumcompute(DBPROCESS * dbprocess);
830int dbnumrets(DBPROCESS * dbproc);
831DBPROCESS *tdsdbopen(LOGINREC * login, const char *server, int msdblib);
832DBPROCESS *dbopen(LOGINREC * login, const char *server);
833
834/* pivot functions */
835struct col_t;
836void dbpivot_count (struct col_t *output, const struct col_t *input);
837void dbpivot_sum (struct col_t *output, const struct col_t *input);
838void dbpivot_min (struct col_t *output, const struct col_t *input);
839void dbpivot_max (struct col_t *output, const struct col_t *input);
840
841struct pivot_t;
842typedef void (*DBPIVOT_FUNC)(struct col_t *output, const struct col_t *input);
843struct pivot_t * dbrows_pivoted(DBPROCESS *dbproc);
844STATUS dbnextrow_pivoted(DBPROCESS *dbproc, struct pivot_t *pp);
845RETCODE dbpivot(DBPROCESS *dbproc, int nkeys, int *keys, int ncols, int *cols, DBPIVOT_FUNC func, int val);
846
847DBPIVOT_FUNC dbpivot_lookup_name( const char name[] );
848
849#ifdef MSDBLIB
850#define dbopen(x,y) tdsdbopen((x),(y), 1)
851#else
852#define dbopen(x,y) tdsdbopen((x),(y), 0)
853#endif
854
855/* fix PHP problem */
856#ifdef PHP_SYBASE_DBOPEN
857#undef PHP_SYBASE_DBOPEN
858#define PHP_SYBASE_DBOPEN dbopen
859#endif
860
861void dbprhead(DBPROCESS * dbproc);
862DBINT dbprcollen(DBPROCESS * dbproc, int column);
863RETCODE dbprrow(DBPROCESS * dbproc);
864const char *dbprtype(int token);
865DBBOOL DRBUF(DBPROCESS * dbprocess);
866STATUS dbreadtext(DBPROCESS * dbproc, void *buf, DBINT bufsize);
867void dbrecftos(const char filename[]);
868RETCODE dbresults(DBPROCESS * dbproc);
869RETCODE dbresults_r(DBPROCESS * dbproc, int recursive);
870BYTE *dbretdata(DBPROCESS * dbproc, int retnum);
871int dbretlen(DBPROCESS * dbproc, int retnum);
872char *dbretname(DBPROCESS * dbproc, int retnum);
873DBINT dbretstatus(DBPROCESS * dbproc);
874int dbrettype(DBPROCESS * dbproc, int retnum);
875RETCODE dbrows(DBPROCESS * dbproc);
876
877#define DBROWS(x) dbrows((x))
878STATUS dbrowtype(DBPROCESS * dbprocess);
879
880#define DBROWTYPE(x) dbrowtype((x))
881RETCODE dbrpcinit(DBPROCESS * dbproc, const char rpcname[], DBSMALLINT options);
882RETCODE dbrpcparam(DBPROCESS * dbproc, const char paramname[], BYTE status, int type, DBINT maxlen, DBINT datalen, BYTE * value);
883RETCODE dbrpcsend(DBPROCESS * dbproc);
884RETCODE dbsafestr(DBPROCESS * dbproc, const char *src, DBINT srclen, char *dest, DBINT destlen, int quotetype);
885RETCODE *dbsechandle(DBINT type, INTFUNCPTR handler);
886char *dbservcharset(DBPROCESS * dbprocess);
887void dbsetavail(DBPROCESS * dbprocess);
888void dbsetbusy(DBPROCESS * dbprocess, DB_DBBUSY_FUNC busyfunc);
889RETCODE dbsetdefcharset(char *charset);
890void dbsetidle(DBPROCESS * dbprocess, DB_DBIDLE_FUNC idlefunc);
891void dbsetifile(char *filename);
892void dbsetinterrupt(DBPROCESS * dbproc, DB_DBCHKINTR_FUNC chkintr, DB_DBHNDLINTR_FUNC hndlintr);
893RETCODE dbsetlogintime(int seconds);
894RETCODE dbsetmaxprocs(int maxprocs);
895RETCODE dbsetnull(DBPROCESS * dbprocess, int bindtype, int bindlen, BYTE * bindval);
896RETCODE dbsetopt(DBPROCESS * dbproc, int option, const char *char_param, int int_param);
897STATUS dbsetrow(DBPROCESS * dbprocess, DBINT row);
898RETCODE dbsettime(int seconds);
899void dbsetuserdata(DBPROCESS * dbproc, BYTE * ptr);
900RETCODE dbsetversion(DBINT version);
901
902int dbspid(DBPROCESS * dbproc);
903RETCODE dbspr1row(DBPROCESS * dbproc, char *buffer, DBINT buf_len);
904DBINT dbspr1rowlen(DBPROCESS * dbproc);
905RETCODE dbsprhead(DBPROCESS * dbproc, char *buffer, DBINT buf_len);
906RETCODE dbsprline(DBPROCESS * dbproc, char *buffer, DBINT buf_len, DBCHAR line_char);
907RETCODE dbsqlexec(DBPROCESS * dbproc);
908RETCODE dbsqlok(DBPROCESS * dbproc);
909RETCODE dbsqlsend(DBPROCESS * dbproc);
910int dbstrbuild(DBPROCESS * dbproc, char *charbuf, int bufsize, char *text, char *formats, ...);
911RETCODE dbstrcpy(DBPROCESS * dbproc, int start, int numbytes, char *dest);
912int dbstrlen(DBPROCESS * dbproc);
913DBINT dbvarylen(DBPROCESS * dbproc, int column);
914
915#define SYBEVERDOWN 100 /* TDS version downgraded . */
916#define SYBEICONVIU 2400 /* Some character(s) could not be converted into client's character set. */
917#define SYBEICONVAVAIL 2401 /* Character set conversion is not available between client character set '%.*s' and server character set '%.*s'.*/
918#define SYBEICONVO 2402 /* Error converting characters into server's character set. Some character(s) could not be converted.*/
919#define SYBEICONVI 2403 /* Some character(s) could not be converted into client's character set. Unconverted bytes were changed to question marks ('?').*/
920#define SYBEICONV2BIG 2404 /* Buffer overflow converting characters from client into server's character set.*/
921 /* cf. doc/dblib_errors.txt for more iconv error values. */
922 /* Reserve a few slots for other iconv-related issues. */
923#define SYBETDSVER 2410 /* Cannot bcp with TDSVER < 5.0 */
924#define SYBEPORT 2500 /* Both port and instance specified */
925#define SYBESYNC 20001 /* Read attempted while out of synchronization with SQL Server. */
926#define SYBEFCON 20002 /* SQL Server connection failed. */
927#define SYBETIME 20003 /* SQL Server connection timed out. */
928#define SYBEREAD 20004 /* Read from SQL Server failed. */
929#define SYBEBUFL 20005 /* DB-LIBRARY internal error - send buffer length corrupted. */
930#define SYBEWRIT 20006 /* Write to SQL Server failed. */
931#define SYBEVMS 20007 /* Sendflush: VMS I/O error. */
932#define SYBESOCK 20008 /* Unable to open socket */
933#define SYBECONN 20009 /* Unable to connect socket -- SQL Server is unavailable or does not exist. */
934#define SYBEMEM 20010 /* Unable to allocate sufficient memory */
935#define SYBEDBPS 20011 /* Maximum number of DBPROCESSes already allocated. */
936#define SYBEINTF 20012 /* Server name not found in interface file */
937#define SYBEUHST 20013 /* Unknown host machine name */
938#define SYBEPWD 20014 /* Incorrect password. */
939#define SYBEOPIN 20015 /* Could not open interface file. */
940#define SYBEINLN 20016 /* Interface file: unexpected end-of-line. */
941#define SYBESEOF 20017 /* Unexpected EOF from SQL Server. */
942#define SYBESMSG 20018 /* General SQL Server error: Check messages from the SQL Server. */
943#define SYBERPND 20019 /* Attempt to initiate a new SQL Server operation with results pending. */
944#define SYBEBTOK 20020 /* Bad token from SQL Server: Data-stream processing out of sync. */
945#define SYBEITIM 20021 /* Illegal timeout value specified. */
946#define SYBEOOB 20022 /* Error in sending out-of-band data to SQL Server. */
947#define SYBEBTYP 20023 /* Unknown bind type passed to DB-LIBRARY function. */
948#define SYBEBNCR 20024 /* Attempt to bind user variable to a non-existent compute row. */
949#define SYBEIICL 20025 /* Illegal integer column length returned by SQL Server. Legal integer lengths are 1, 2, and 4 bytes. */
950#define SYBECNOR 20026 /* Column number out of range. */
951#define SYBENPRM 20027 /* NULL parameter not allowed for this dboption. */
952#define SYBEUVDT 20028 /* Unknown variable-length datatype encountered. */
953#define SYBEUFDT 20029 /* Unknown fixed-length datatype encountered. */
954#define SYBEWAID 20030 /* DB-LIBRARY internal error: ALTFMT following ALTNAME has wrong id. */
955#define SYBECDNS 20031 /* Datastream indicates that a compute column is derived from a non-existent select-list member. */
956#define SYBEABNC 20032 /* Attempt to bind to a non-existent column. */
957#define SYBEABMT 20033 /* User attempted a dbbind() with mismatched column and variable types. */
958#define SYBEABNP 20034 /* Attempt to bind using NULL pointers. */
959#define SYBEAAMT 20035 /* User attempted a dbaltbind() with mismatched column and variable types. */
960#define SYBENXID 20036 /* The Server did not grant us a distributed-transaction ID. */
961#define SYBERXID 20037 /* The Server did not recognize our distributed-transaction ID. */
962#define SYBEICN 20038 /* Invalid computeid or compute column number. */
963#define SYBENMOB 20039 /* No such member of 'order by' clause. */
964#define SYBEAPUT 20040 /* Attempt to print unknown token. */
965#define SYBEASNL 20041 /* Attempt to set fields in a null loginrec. */
966#define SYBENTLL 20042 /* Name too long for loginrec field. */
967#define SYBEASUL 20043 /* Attempt to set unknown loginrec field. */
968#define SYBERDNR 20044 /* Attempt to retrieve data from a non-existent row. */
969#define SYBENSIP 20045 /* Negative starting index passed to dbstrcpy(). */
970#define SYBEABNV 20046 /* Attempt to bind to a NULL program variable. */
971#define SYBEDDNE 20047 /* DBPROCESS is dead or not enabled. */
972#define SYBECUFL 20048 /* Data-conversion resulted in underflow. */
973#define SYBECOFL 20049 /* Data-conversion resulted in overflow. */
974#define SYBECSYN 20050 /* Attempt to convert data stopped by syntax error in source field. */
975#define SYBECLPR 20051 /* Data-conversion resulted in loss of precision. */
976#define SYBECNOV 20052 /* Attempt to set variable to NULL resulted in overflow. */
977#define SYBERDCN 20053 /* Requested data-conversion does not exist. */
978#define SYBESFOV 20054 /* dbsafestr() overflowed its destination buffer. */
979#define SYBEUNT 20055 /* Unknown network type found in interface file. */
980#define SYBECLOS 20056 /* Error in closing network connection. */
981#define SYBEUAVE 20057 /* Unable to allocate VMS event flag. */
982#define SYBEUSCT 20058 /* Unable to set communications timer. */
983#define SYBEEQVA 20059 /* Error in queueing VMS AST routine. */
984#define SYBEUDTY 20060 /* Unknown datatype encountered. */
985#define SYBETSIT 20061 /* Attempt to call dbtsput() with an invalid timestamp. */
986#define SYBEAUTN 20062 /* Attempt to update the timestamp of a table which has no timestamp column. */
987#define SYBEBDIO 20063 /* Bad bulk-copy direction. Must be either IN or OUT. */
988#define SYBEBCNT 20064 /* Attempt to use Bulk Copy with a non-existent Server table. */
989#define SYBEIFNB 20065 /* Illegal field number passed to bcp_control(). */
990#define SYBETTS 20066 /* The table which bulk-copy is attempting to copy to a host-file is shorter than the number of rows which bulk-copy was instructed to skip. */
991#define SYBEKBCO 20067 /* 1000 rows successfully bulk-copied to host-file. */
992#define SYBEBBCI 20068 /* Batch successfully bulk-copied to SQL Server. */
993#define SYBEKBCI 20069 /* Bcp: 1000 rows sent to SQL Server. */
994#define SYBEBCRE 20070 /* I/O error while reading bcp data-file. */
995#define SYBETPTN 20071 /* Syntax error: only two periods are permitted in table names. */
996#define SYBEBCWE 20072 /* I/O error while writing bcp data-file. */
997#define SYBEBCNN 20073 /* Attempt to bulk-copy a NULL value into Server column %d, which does not accept NULL values. */
998#define SYBEBCOR 20074 /* Attempt to bulk-copy an oversized row to the SQL Server. */
999#define SYBEBCIS 20075 /* Attempt to bulk-copy an illegally-sized column value to the SQL Server. */
1000#define SYBEBCPI 20076 /* bcp_init() must be called before any other bcp routines. */
1001#define SYBEBCPN 20077 /* bcp_bind(), bcp_collen(), bcp_colptr(), bcp_moretext() and bcp_sendrow() may be used only after bcp_init() has been called with the copy direction set to DB_IN. */
1002#define SYBEBCPB 20078 /* bcp_bind(), bcp_moretext() and bcp_sendrow() may NOT be used after bcp_init() has been passed a non-NULL input file name. */
1003#define SYBEVDPT 20079 /* For bulk copy, all variable-length data must have either a length-prefix or a terminator specified. */
1004#define SYBEBIVI 20080 /* bcp_columns(), bcp_colfmt() and bcp_colfmt_ps() may be used only after bcp_init() has been passed a valid input file. */
1005#define SYBEBCBC 20081 /* bcp_columns() must be called before bcp_colfmt() and bcp_colfmt_ps(). */
1006#define SYBEBCFO 20082 /* Bcp host-files must contain at least one column. */
1007#define SYBEBCVH 20083 /* bcp_exec() may be called only after bcp_init() has been passed a valid host file. */
1008#define SYBEBCUO 20084 /* Bcp: Unable to open host data-file. */
1009#define SYBEBCUC 20085 /* Bcp: Unable to close host data-file. */
1010#define SYBEBUOE 20086 /* Bcp: Unable to open error-file. */
1011#define SYBEBUCE 20087 /* Bcp: Unable to close error-file. */
1012#define SYBEBWEF 20088 /* I/O error while writing bcp error-file. */
1013#define SYBEASTF 20089 /* VMS: Unable to setmode for control_c ast. */
1014#define SYBEUACS 20090 /* VMS: Unable to assign channel to sys$command. */
1015#define SYBEASEC 20091 /* Attempt to send an empty command buffer to the SQL Server. */
1016#define SYBETMTD 20092 /* Attempt to send too much TEXT data via the dbmoretext() call. */
1017#define SYBENTTN 20093 /* Attempt to use dbtxtsput() to put a new text-timestamp into a non-existent data row. */
1018#define SYBEDNTI 20094 /* Attempt to use dbtxtsput() to put a new text-timestamp into a column whose datatype is neither SYBTEXT nor SYBIMAGE. */
1019#define SYBEBTMT 20095 /* Attempt to send too much TEXT data via the bcp_moretext() call. */
1020#define SYBEORPF 20096 /* Attempt to set remote password would overflow the login-record's remote-password field. */
1021#define SYBEUVBF 20097 /* Attempt to read an unknown version of BCP format-file. */
1022#define SYBEBUOF 20098 /* Bcp: Unable to open format-file. */
1023#define SYBEBUCF 20099 /* Bcp: Unable to close format-file. */
1024#define SYBEBRFF 20100 /* I/O error while reading bcp format-file. */
1025#define SYBEBWFF 20101 /* I/O error while writing bcp format-file. */
1026#define SYBEBUDF 20102 /* Bcp: Unrecognized datatype found in format-file. */
1027#define SYBEBIHC 20103 /* Incorrect host-column number found in bcp format-file. */
1028#define SYBEBEOF 20104 /* Unexpected EOF encountered in BCP data-file. */
1029#define SYBEBCNL 20105 /* Negative length-prefix found in BCP data-file. */
1030#define SYBEBCSI 20106 /* Host-file columns may be skipped only when copying INto the Server. */
1031#define SYBEBCIT 20107 /* It's illegal to use BCP terminators with program variables other than SYBCHAR, SYBBINARY, SYBTEXT, or SYBIMAGE. */
1032#define SYBEBCSA 20108 /* The BCP hostfile '%s' contains only %ld rows. Skipping all of these rows is not allowed. */
1033#define SYBENULL 20109 /* NULL DBPROCESS pointer passed to DB-Library. */
1034#define SYBEUNAM 20110 /* Unable to get current username from operating system. */
1035#define SYBEBCRO 20111 /* The BCP hostfile '%s' contains only %ld rows. It was impossible to read the requested %ld rows. */
1036#define SYBEMPLL 20112 /* Attempt to set maximum number of DBPROCESSes lower than 1. */
1037#define SYBERPIL 20113 /* It is illegal to pass -1 to dbrpcparam() for the datalen of parameters which are of type SYBCHAR, SYBVARCHAR, SYBBINARY, or SYBVARBINARY. */
1038#define SYBERPUL 20114 /* When passing a SYBINTN, SYBDATETIMN, SYBMONEYN, or SYBFLTN parameter via dbrpcparam(), it's necessary to specify the parameter's maximum or actual length, so that DB-Library can recognize it as a SYBINT1, SYBINT2, SYBINT4, SYBMONEY, or SYBMONEY4, etc. */
1039#define SYBEUNOP 20115 /* Unknown option passed to dbsetopt(). */
1040#define SYBECRNC 20116 /* The current row is not a result of compute clause %d, so it is illegal to attempt to extract that data from this row. */
1041#define SYBERTCC 20117 /* dbreadtext() may not be used to receive the results of a query which contains a COMPUTE clause. */
1042#define SYBERTSC 20118 /* dbreadtext() may only be used to receive the results of a query which contains a single result column. */
1043#define SYBEUCRR 20119 /* Internal software error: Unknown connection result reported by * dbpasswd(). */
1044#define SYBERPNA 20120 /* The RPC facility is available only when using a SQL Server whose version number is 4.0 or greater. */
1045#define SYBEOPNA 20121 /* The text/image facility is available only when using a SQL Server whose version number is 4.0 or greater. */
1046#define SYBEFGTL 20122 /* Bcp: Row number of the first row to be copied cannot be greater than the row number for the last row to be copied. */
1047#define SYBECWLL 20123 /* Attempt to set column width less than 1. */
1048#define SYBEUFDS 20124 /* Unrecognized format encountered in dbstrbuild(). */
1049#define SYBEUCPT 20125 /* Unrecognized custom-format parameter-type encountered in dbstrbuild(). */
1050#define SYBETMCF 20126 /* Attempt to install too many custom formats via dbfmtinstall(). */
1051#define SYBEAICF 20127 /* Error in attempting to install custom format. */
1052#define SYBEADST 20128 /* Error in attempting to determine the size of a pair of translation tables. */
1053#define SYBEALTT 20129 /* Error in attempting to load a pair of translation tables. */
1054#define SYBEAPCT 20130 /* Error in attempting to perform a character-set translation. */
1055#define SYBEXOCI 20131 /* A character-set translation overflowed its destination buffer while using bcp to copy data from a host-file to the SQL Server. */
1056#define SYBEFSHD 20132 /* Error in attempting to find the Sybase home directory. */
1057#define SYBEAOLF 20133 /* Error in attempting to open a localization file. */
1058#define SYBEARDI 20134 /* Error in attempting to read datetime information from a localization file. */
1059#define SYBEURCI 20135 /* Unable to read copyright information from the dblib localization file. */
1060#define SYBEARDL 20136 /* Error in attempting to read the dblib.loc localization file. */
1061#define SYBEURMI 20137 /* Unable to read money-format information from the dblib localization file. */
1062#define SYBEUREM 20138 /* Unable to read error mnemonic from the dblib localization file. */
1063#define SYBEURES 20139 /* Unable to read error string from the dblib localization file. */
1064#define SYBEUREI 20140 /* Unable to read error information from the dblib localization file. */
1065#define SYBEOREN 20141 /* Warning: an out-of-range error-number was encountered in dblib.loc. The maximum permissible error-number is defined as DBERRCOUNT in sybdb.h. */
1066#define SYBEISOI 20142 /* Invalid sort-order information found. */
1067#define SYBEIDCL 20143 /* Illegal datetime column length returned by DataServer. Legal datetime lengths are 4 and 8 bytes. */
1068#define SYBEIMCL 20144 /* Illegal money column length returned by DataServer. Legal money lengths are 4 and 8 bytes. */
1069#define SYBEIFCL 20145 /* Illegal floating-point column length returned by DataServer. Legal floating-point lengths are 4 and 8 bytes. */
1070#define SYBEUTDS 20146 /* Unrecognized TDS version received from SQL Server. */
1071#define SYBEBUFF 20147 /* Bcp: Unable to create format-file. */
1072#define SYBEACNV 20148 /* Attemp to do conversion with NULL destination variable. */
1073#define SYBEDPOR 20149 /* Out-of-range datepart constant. */
1074#define SYBENDC 20150 /* Cannot have negative component in date in numeric form. */
1075#define SYBEMVOR 20151 /* Month values must be between 1 and 12. */
1076#define SYBEDVOR 20152 /* Day values must be between 1 and 7. */
1077#define SYBENBVP 20153 /* Cannot pass dbsetnull() a NULL bindval pointer. */
1078#define SYBESPID 20154 /* Called dbspid() with a NULL dbproc. */
1079#define SYBENDTP 20155 /* Called dbdatecrack() with a NULL datetime parameter. */
1080#define SYBEXTN 20156 /* The xlt_todisp and xlt_tosrv parameters to dbfree_xlate() were NULL. */
1081#define SYBEXTDN 20157 /* Warning: the xlt_todisp parameter to dbfree_xlate() was NULL. The space associated with the xlt_tosrv parameter has been freed. */
1082#define SYBEXTSN 20158 /* Warning: the xlt_tosrv parameter to dbfree_xlate() was NULL. The space associated with the xlt_todisp parameter has been freed. */
1083#define SYBENUM 20159 /* Incorrect number of arguments given to DB-Library. */
1084#define SYBETYPE 20160 /* Invalid argument type given to DB-Library. */
1085#define SYBEGENOS 20161 /* General Operating System Error. */
1086#define SYBEPAGE 20162 /* wrong resource type or length given for dbpage() operation. */
1087#define SYBEOPTNO 20163 /* Option is not allowed or is unreconized */
1088#define SYBEETD 20164 /* Failure to send the expected amount of TEXT or IMAGE data via dbmoretext(). */
1089#define SYBERTYPE 20165 /* Invalid resource type given to DB-Library. */
1090#define SYBERFILE 20166 /* "Can not open resource file." */
1091#define SYBEFMODE 20167 /* Read/Write/Append mode denied on file. */
1092#define SYBESLCT 20168 /* Could not select or copy field specified */
1093#define SYBEZTXT 20169 /* Attempt to send zero length TEXT or IMAGE to dataserver via dbwritetext(). */
1094#define SYBENTST 20170 /* The file being opened must be a stream_lf. */
1095#define SYBEOSSL 20171 /* Operating system login level not in range of Secure SQL Server */
1096#define SYBEESSL 20172 /* Login security level entered does not agree with operating system level */
1097#define SYBENLNL 20173 /* Program not linked with specified network library. */
1098#define SYBENHAN 20174 /* called dbrecvpassthru() with a NULL handler parameter. */
1099#define SYBENBUF 20175 /* called dbsendpassthru() with a NULL buf pointer. */
1100#define SYBENULP 20176 /* Called %s with a NULL %s parameter. */
1101#define SYBENOTI 20177 /* No event handler installed. */
1102#define SYBEEVOP 20178 /* Called dbregwatch() with a bad options parameter. */
1103#define SYBENEHA 20179 /* Called dbreghandle() with a NULL handler parameter. */
1104#define SYBETRAN 20180 /* DBPROCESS is being used for another transaction. */
1105#define SYBEEVST 20181 /* Must initiate a transaction before calling dbregparam(). */
1106#define SYBEEINI 20182 /* Must call dbreginit() before dbregraise(). */
1107#define SYBEECRT 20183 /* Must call dbregdefine() before dbregcreate(). */
1108#define SYBEECAN 20184 /* Attempted to cancel unrequested event notification. */
1109#define SYBEEUNR 20185 /* Unsolicited event notification received. */
1110#define SYBERPCS 20186 /* Must call dbrpcinit() before dbrpcparam(). */
1111#define SYBETPAR 20187 /* No SYBTEXT or SYBIMAGE parameters were defined. */
1112#define SYBETEXS 20188 /* Called dbmoretext() with a bad size parameter. */
1113#define SYBETRAC 20189 /* Attempted to turn off a trace flag that was not on. */
1114#define SYBETRAS 20190 /* DB-Library internal error - trace structure not found. */
1115#define SYBEPRTF 20191 /* dbtracestring() may only be called from a printfunc(). */
1116#define SYBETRSN 20192 /* Bad numbytes parameter passed to dbtracestring(). */
1117#define SYBEBPKS 20193 /* In DBSETLPACKET(), the packet size parameter must be between 0 and 999999. */
1118#define SYBEIPV 20194 /* %1! is an illegal value for the %2! parameter of %3!. */
1119#define SYBEMOV 20195 /* Money arithmetic resulted in overflow in function %1!. */
1120#define SYBEDIVZ 20196 /* Attempt to divide by $0.00 in function %1!. */
1121#define SYBEASTL 20197 /* Synchronous I/O attempted at AST level. */
1122#define SYBESEFA 20198 /* DBSETNOTIFS cannot be called if connections are present. */
1123#define SYBEPOLL 20199 /* Only one dbpoll() can be active at a time. */
1124#define SYBENOEV 20200 /* dbpoll() cannot be called if registered procedure notifications have been disabled. */
1125#define SYBEBADPK 20201 /* Packet size of %1! not supported. -- size of %2! used instead. */
1126#define SYBESECURE 20202 /* Secure Server function not supported in this version. */
1127#define SYBECAP 20203 /* DB-Library capabilities not accepted by the Server. */
1128#define SYBEFUNC 20204 /* Functionality not supported at the specified version level. */
1129#define SYBERESP 20205 /* Response function address passed to dbresponse() must be non-NULL. */
1130#define SYBEIVERS 20206 /* Illegal version level specified. */
1131#define SYBEONCE 20207 /* Function can be called only once. */
1132#define SYBERPNULL 20208 /* value parameter for dbprcparam() can be NULL, only if the datalen parameter is 0 */
1133#define SYBERPTXTIM 20209 /* RPC parameters cannot be of type Text/Image. */
1134#define SYBENEG 20210 /* Negotiated login attempt failed. */
1135#define SYBELBLEN 20211 /* Security labels should be less than 256 characters long. */
1136#define SYBEUMSG 20212 /* Unknown message-id in MSG datastream. */
1137#define SYBECAPTYP 20213 /* Unexpected capability type in CAPABILITY datastream. */
1138#define SYBEBNUM 20214 /* Bad numbytes parameter passed to dbstrcpy() */
1139#define SYBEBBL 20215 /* Bad bindlen parameter passed to dbsetnull() */
1140#define SYBEBPREC 20216 /* Illegal precision specified */
1141#define SYBEBSCALE 20217 /* Illegal scale specified */
1142#define SYBECDOMAIN 20218 /* Source field value is not within the domain of legal values. */
1143#define SYBECINTERNAL 20219 /* Internal Conversion error. */
1144#define SYBEBTYPSRV 20220 /* Datatype is not supported by the server. */
1145#define SYBEBCSET 20221 /* Unknown character-set encountered." */
1146#define SYBEFENC 20222 /* Password Encryption failed." */
1147#define SYBEFRES 20223 /* Challenge-Response function failed.", */
1148#define SYBEISRVPREC 20224 /* Illegal precision value returned by the server. */
1149#define SYBEISRVSCL 20225 /* Illegal scale value returned by the server. */
1150#define SYBEINUMCL 20226 /* Invalid numeric column length returned by the server. */
1151#define SYBEIDECCL 20227 /* Invalid decimal column length returned by the server. */
1152#define SYBEBCMTXT 20228 /* bcp_moretext() may be used only when there is at least one text or image column in the server table. */
1153#define SYBEBCPREC 20229 /* Column %1!: Illegal precision value encountered. */
1154#define SYBEBCBNPR 20230 /* bcp_bind(): if varaddr is NULL, prefixlen must be 0 and no terminator should be specified. */
1155#define SYBEBCBNTYP 20231 /* bcp_bind(): if varaddr is NULL and varlen greater than 0, the table column type must be SYBTEXT or SYBIMAGE and the program variable type must be SYBTEXT, SYBCHAR, SYBIMAGE or SYBBINARY. */
1156#define SYBEBCSNTYP 20232 /* column number %1!: if varaddr is NULL and varlen greater than 0, the table column type must be SYBTEXT or SYBIMAGE and the program variable type must be SYBTEXT, SYBCHAR, SYBIMAGE or SYBBINARY. */
1157#define SYBEBCPCTYP 20233 /* bcp_colfmt(): If table_colnum is 0, host_type cannot be 0. */
1158#define SYBEBCVLEN 20234 /* varlen should be greater than or equal to -1. */
1159#define SYBEBCHLEN 20235 /* host_collen should be greater than or equal to -1. */
1160#define SYBEBCBPREF 20236 /* Illegal prefix length. Legal values are 0, 1, 2 or 4. */
1161#define SYBEBCPREF 20237 /* Illegal prefix length. Legal values are -1, 0, 1, 2 or 4. */
1162#define SYBEBCITBNM 20238 /* bcp_init(): tblname parameter cannot be NULL. */
1163#define SYBEBCITBLEN 20239 /* bcp_init(): tblname parameter is too long. */
1164#define SYBEBCSNDROW 20240 /* bcp_sendrow() may NOT be called unless all text data for the previous row has been sent using bcp_moretext(). */
1165#define SYBEBPROCOL 20241 /* bcp protocol error: returned column count differs from the actual number of columns received. */
1166#define SYBEBPRODEF 20242 /* bcp protocol error: expected default information and got none. */
1167#define SYBEBPRONUMDEF 20243 /* bcp protocol error: expected number of defaults differs from the actual number of defaults received. */
1168#define SYBEBPRODEFID 20244 /* bcp protocol error: default column id and actual column id are not same */
1169#define SYBEBPRONODEF 20245 /* bcp protocol error: default value received for column that does not have default. */
1170#define SYBEBPRODEFTYP 20246 /* bcp protocol error: default value datatype differs from column datatype. */
1171#define SYBEBPROEXTDEF 20247 /* bcp protocol error: more than one row of default information received. */
1172#define SYBEBPROEXTRES 20248 /* bcp protocol error: unexpected set of results received. */
1173#define SYBEBPROBADDEF 20249 /* bcp protocol error: illegal default column id received. */
1174#define SYBEBPROBADTYP 20250 /* bcp protocol error: unknown column datatype. */
1175#define SYBEBPROBADLEN 20251 /* bcp protocol error: illegal datatype length received. */
1176#define SYBEBPROBADPREC 20252 /* bcp protocol error: illegal precision value received. */
1177#define SYBEBPROBADSCL 20253 /* bcp protocol error: illegal scale value received. */
1178#define SYBEBADTYPE 20254 /* Illegal value for type parameter given to %1!. */
1179#define SYBECRSNORES 20255 /* Cursor statement generated no results. */
1180#define SYBECRSNOIND 20256 /* One of the tables involved in the cursor statement does not have a unique index. */
1181#define SYBECRSVIEW 20257 /* A view cannot be joined with another table or a view in a cursor statement. */
1182#define SYBECRSVIIND 20258 /* The view used in the cursor statement does not include all the unique index columns of the underlying tables. */
1183#define SYBECRSORD 20259 /* Only fully keyset driven cursors can have 'order by', ' group by', or 'having' phrases. */
1184#define SYBECRSBUFR 20260 /* Row buffering should not be turned on when using cursor APIs. */
1185#define SYBECRSNOFREE 20261 /* The DBNOAUTOFREE option should not be turned on when using cursor APIs. */
1186#define SYBECRSDIS 20262 /* Cursor statement contains one of the disallowed phrases 'compute', 'union', 'for browse', or 'select into'. */
1187#define SYBECRSAGR 20263 /* Aggregate functions are not allowed in a cursor statement. */
1188#define SYBECRSFRAND 20264 /* Fetch types RANDOM and RELATIVE can only be used within the keyset of keyset driven cursors. */
1189#define SYBECRSFLAST 20265 /* Fetch type LAST requires fully keyset driven cursors. */
1190#define SYBECRSBROL 20266 /* Backward scrolling cannot be used in a forward scrolling cursor. */
1191#define SYBECRSFROWN 20267 /* Row number to be fetched is outside valid range. */
1192#define SYBECRSBSKEY 20268 /* Keyset cannot be scrolled backward in mixed cursors with a previous fetch type. */
1193#define SYBECRSRO 20269 /* Data locking or modifications cannot be made in a READONLY cursor. */
1194#define SYBECRSNOCOUNT 20270 /* The DBNOCOUNT option should not be turned on when doing updates or deletes with dbcursor(). */
1195#define SYBECRSTAB 20271 /* Table name must be determined in operations involving data locking or modifications. */
1196#define SYBECRSUPDNB 20272 /* Update or insert operations cannot use bind variables when binding type is NOBIND. */
1197#define SYBECRSNOWHERE 20273 /* A WHERE clause is not allowed in a cursor update or insert. */
1198#define SYBECRSSET 20274 /* A SET clause is required for a cursor update or insert. */
1199#define SYBECRSUPDTAB 20275 /* Update or insert operations using bind variables require single table cursors. */
1200#define SYBECRSNOUPD 20276 /* Update or delete operation did not affect any rows. */
1201#define SYBECRSINV 20277 /* Invalid cursor statement. */
1202#define SYBECRSNOKEYS 20278 /* The entire keyset must be defined for KEYSET cursors. */
1203#define SYBECRSNOBIND 20279 /* Cursor bind must be called prior to updating cursor */
1204#define SYBECRSFTYPE 20280 /* Unknown fetch type. */
1205#define SYBECRSINVALID 20281 /* The cursor handle is invalid. */
1206#define SYBECRSMROWS 20282 /* Multiple rows are returned, only one is expected. */
1207#define SYBECRSNROWS 20283 /* No rows returned, at least one is expected. */
1208#define SYBECRSNOLEN 20284 /* No unique index found. */
1209#define SYBECRSNOPTCC 20285 /* No OPTCC was found. */
1210#define SYBECRSNORDER 20286 /* The order of clauses must be from, where, and order by. */
1211#define SYBECRSNOTABLE 20287 /* Table name is NULL. */
1212#define SYBECRSNUNIQUE 20288 /* No unique keys associated with this view. */
1213#define SYBECRSVAR 20289 /* There is no valid address associated with this bind. */
1214#define SYBENOVALUE 20290 /* Security labels require both a name and a value */
1215#define SYBEVOIDRET 20291 /* Parameter of type SYBVOID cannot be a return parameter. */
1216#define SYBECLOSEIN 20292 /* Unable to close interface file. */
1217#define SYBEBOOL 20293 /* Boolean parameters must be TRUE or FALSE. */
1218#define SYBEBCPOPT 20294 /* The option cannot be called while a bulk copy operation is progress. */
1219#define SYBEERRLABEL 20295 /* An illegal value was returned from the security label handler. */
1220#define SYBEATTNACK 20296 /* Timed out waiting for server to acknowledge attention." */
1221#define SYBEBBFL 20297 /* -001- Batch failed in bulk-copy to SQL Server */
1222#define SYBEDCL 20298 /* -004- DCL Error */
1223#define SYBECS 20299 /* -004- cs context Error */
1224#define SYBEBULKINSERT 20599 /* cannot build bulk insert statement */
1225#define SYBECOLSIZE 22000 /* Invalid column information structure size */
1226
1227int dbtds(DBPROCESS * dbprocess);
1228
1229#define DBTDS(a) dbtds(a)
1230DBINT dbtextsize(DBPROCESS * dbprocess);
1231DBBINARY *dbtxptr(DBPROCESS * dbproc, int column);
1232DBBINARY *dbtxtimestamp(DBPROCESS * dbproc, int column);
1233DBBINARY *dbtxtsnewval(DBPROCESS * dbprocess);
1234RETCODE dbtxtsput(DBPROCESS * dbprocess, DBBINARY newtxts, int colnum);
1235RETCODE dbuse(DBPROCESS * dbproc, const char *name);
1236const char *dbversion(void);
1237DBBOOL dbwillconvert(int srctype, int desttype);
1238RETCODE dbwritetext(DBPROCESS * dbproc, char *objname, DBBINARY * textptr, DBTINYINT textptrlen, DBBINARY * timestamp,
1239 DBBOOL log, DBINT size, BYTE * text);
1240
1241/* LOGINREC manipulation */
1242RETCODE dbsetlname(LOGINREC * login, const char *value, int which);
1243RETCODE dbsetlbool(LOGINREC * login, int value, int which);
1244RETCODE dbsetlshort(LOGINREC * login, int value, int which);
1245RETCODE dbsetllong(LOGINREC * login, long value, int which);
1246RETCODE dbsetlversion (LOGINREC * login, BYTE version);
1247
1248#define DBSETHOST 1
1249#define DBSETLHOST(x,y) dbsetlname((x), (y), DBSETHOST)
1250#define dbsetlhost(x,y) dbsetlname((x), (y), DBSETHOST)
1251#define DBSETUSER 2
1252#define DBSETLUSER(x,y) dbsetlname((x), (y), DBSETUSER)
1253#define dbsetluser(x,y) dbsetlname((x), (y), DBSETUSER)
1254#define DBSETPWD 3
1255#define DBSETLPWD(x,y) dbsetlname((x), (y), DBSETPWD)
1256#define dbsetlpwd(x,y) dbsetlname((x), (y), DBSETPWD)
1257#if defined(DBLIB_UNIMPLEMENTED)
1258# define DBSETHID 4 /* not implemented */
1259# define DBSETLHID(x,y) dbsetlname((x), (y), DBSETHID)
1260#endif
1261#define DBSETAPP 5
1262#define DBSETLAPP(x,y) dbsetlname((x), (y), DBSETAPP)
1263#define dbsetlapp(x,y) dbsetlname((x), (y), DBSETAPP)
1264#define DBSETBCP 6
1265#define BCP_SETL(x,y) dbsetlbool((x), (y), DBSETBCP)
1266#define DBSETLSECURE(x) dbsetlbool((x), (1), DBSETBCP)
1267#define DBSETNATLANG 7
1268#define DBSETLNATLANG(x,y) dbsetlname((x), (y), DBSETNATLANG)
1269#define dbsetlnatlang(x,y) dbsetlname((x), (y), DBSETNATLANG)
1270#if defined(DBLIB_UNIMPLEMENTED)
1271# define DBSETNOSHORT 8 /* not implemented */
1272# define DBSETLNOSHORT(x,y) dbsetlbool((x), (y), DBSETNOSHORT)
1273# define DBSETHIER 9 /* not implemented */
1274# define DBSETLHIER(x,y) dbsetlshort((x), (y), DBSETHIER)
1275#endif
1276#define DBSETCHARSET 10
1277#define DBSETLCHARSET(x,y) dbsetlname((x), (y), DBSETCHARSET)
1278#define DBSETPACKET 11
1279#define DBSETLPACKET(x,y) dbsetllong((x), (y), DBSETPACKET)
1280#define dbsetlpacket(x,y) dbsetllong((x), (y), DBSETPACKET)
1281#define DBSETENCRYPT 12
1282#define DBSETLENCRYPT(x,y) dbsetlbool((x), (y), DBSETENCRYPT)
1283#define DBSETLABELED 13
1284#define DBSETLLABELED(x,y) dbsetlbool((x), (y), DBSETLABELED)
1285#define BCP_SETLABELED(x,y) dbsetlbool((x), (y), DBSETLABELED)
1286#define DBSETDBNAME 14
1287#define DBSETLDBNAME(x,y) dbsetlname((x), (y), DBSETDBNAME)
1288#define DBSETLVERSION(login, version) dbsetlversion((login), (version))
1289#define DBSETNETWORKAUTH 101
1290#define DBSETLNETWORKAUTH(x, y) dbsetlbool((x), (y), DBSETNETWORKAUTH)
1291#define DBSETMUTUALAUTH 102
1292#define DBSETLMUTUALAUTH(x, y) dbsetlbool((x), (y), DBSETMUTUALAUTH)
1293#define DBSETSERVERPRINCIPAL 103
1294#define DBSETLSERVERPRINCIPAL(x,y) dbsetlname((x), (y), DBSETSERVERPRINCIPAL)
1295/* settings from here are purely FreeTDS extensions */
1296#define DBSETUTF16 1001
1297#define DBSETLUTF16(x,y) dbsetlbool((x), (y), DBSETUTF16)
1298#define DBSETNTLMV2 1002
1299#define DBSETLNTLMV2(x,y) dbsetlbool((x), (y), DBSETNTLMV2)
1300#define DBSETREADONLY 1003
1301#define DBSETLREADONLY(x,y) dbsetlbool((x), (y), DBSETREADONLY)
1302#define DBSETDELEGATION 1004
1303#define DBSETLDELEGATION(x, y) dbsetlbool((x), (y), DBSETDELEGATION)
1304#define DBSETENCRYPTION 1005
1305#define DBSETLENCRYPTION(x, y) dbsetlname((x), (y), DBSETENCRYPTION)
1306#define DBSETPORT 1006
1307#define DBSETLPORT(x,y) dbsetlshort((x), (y), DBSETPORT)
1308
1309RETCODE bcp_init(DBPROCESS * dbproc, const char *tblname, const char *hfile, const char *errfile, int direction);
1310DBINT bcp_done(DBPROCESS * dbproc);
1311
1312DBINT bcp_batch(DBPROCESS * dbproc);
1313RETCODE bcp_bind(DBPROCESS * dbproc, BYTE * varaddr, int prefixlen, DBINT varlen, BYTE * terminator, int termlen, int type,
1314 int table_column);
1315RETCODE bcp_collen(DBPROCESS * dbproc, DBINT varlen, int table_column);
1316RETCODE bcp_columns(DBPROCESS * dbproc, int host_colcount);
1317RETCODE bcp_colfmt(DBPROCESS * dbproc, int host_column, int host_type, int host_prefixlen, DBINT host_collen,
1318 const BYTE * host_term, int host_termlen, int colnum);
1319RETCODE bcp_colfmt_ps(DBPROCESS * dbproc, int host_column, int host_type, int host_prefixlen, DBINT host_collen,
1320 BYTE * host_term, int host_termlen, int colnum, DBTYPEINFO * typeinfo);
1321RETCODE bcp_colptr(DBPROCESS * dbproc, BYTE * colptr, int table_column);
1322RETCODE bcp_control(DBPROCESS * dbproc, int field, DBINT value);
1323int bcp_getbatchsize(DBPROCESS * dbproc); /* FreeTDS only */
1324RETCODE bcp_exec(DBPROCESS * dbproc, DBINT * rows_copied);
1325DBBOOL bcp_getl(LOGINREC * login);
1326RETCODE bcp_options(DBPROCESS * dbproc, int option, BYTE * value, int valuelen);
1327RETCODE bcp_readfmt(DBPROCESS * dbproc, const char filename[]);
1328RETCODE bcp_sendrow(DBPROCESS * dbproc);
1329
1330#ifdef __cplusplus
1331#if 0
1332{
1333#endif
1334}
1335#endif
1336
1337#endif
RETCODE dbcolinfo(DBPROCESS *dbproc, CI_TYPE type, DBINT column, DBINT computeid, DBCOL *pdbcol)
Get a bunch of column attributes with a single call (Microsoft-compatibility feature).
Definition dblib.c:3062
RETCODE dbpivot(DBPROCESS *dbproc, int nkeys, int *keys, int ncols, int *cols, DBPIVOT_FUNC func, int val)
Pivot the rows, creating a new resultset.
Definition dbpivot.c:974
void dbclrbuf(DBPROCESS *dbproc, DBINT n)
Clear n rows from the row buffer.
Definition dblib.c:2860
DBTYPEINFO * dbcoltypeinfo(DBPROCESS *dbproc, int column)
Get precision and scale information for a regular result column.
Definition dblib.c:3033
LOGINREC * dblogin(void)
Allocate a LOGINREC structure.
Definition dblib.c:713
void dbfreebuf(DBPROCESS *dbproc)
Erase the command buffer, in case DBNOAUTOFREE was set with dbsetopt().
Definition dblib.c:6102
BYTE * dbdata(DBPROCESS *dbproc, int column)
Get address of data in a regular result column.
Definition dblib.c:3371
int dbstrlen(DBPROCESS *dbproc)
Get size of the command buffer, in bytes.
Definition dblib.c:6333
BYTE * dbadata(DBPROCESS *dbproc, int computeid, int column)
Get address of compute column data.
Definition dblib.c:4457
int dbspid(DBPROCESS *dbproc)
Get server process ID for a DBPROCESS.
Definition dblib.c:5962
DBBINARY * dbtxtimestamp(DBPROCESS *dbproc, int column)
Get text timestamp for a column in the current row.
Definition dblib.c:6569
BYTE * dbbylist(DBPROCESS *dbproc, int computeid, int *size)
Get bylist for a compute row.
Definition dblib.c:5041
char * dbservcharset(DBPROCESS *dbprocess)
Get syscharset name of the server character set.
Definition dblib.c:7067
DBINT dbspr1rowlen(DBPROCESS *dbproc)
Determine size buffer required to hold the results returned by dbsprhead(), dbsprline(),...
Definition dblib.c:3438
DBINT dbconvert(DBPROCESS *dbproc, int srctype, const BYTE *src, DBINT srclen, int desttype, BYTE *dest, DBINT destlen)
cf.
Definition dblib.c:2612
DBINT dbadlen(DBPROCESS *dbproc, int computeid, int column)
Get size of data in a compute column.
Definition dblib.c:4352
void dbsetinterrupt(DBPROCESS *dbproc, DB_DBCHKINTR_FUNC chkintr, DB_DBHNDLINTR_FUNC hndlintr)
Set interrupt handler for db-lib to use while blocked against a read from the server.
Definition dblib.c:4673
RETCODE dbsetnull(DBPROCESS *dbprocess, int bindtype, int bindlen, BYTE *bindval)
Define substitution values to be used when binding null values.
Definition dblib.c:1981
char * dbcolname(DBPROCESS *dbproc, int column)
Return name of a regular result column.
Definition dblib.c:1891
RETCODE dbfcmd(DBPROCESS *dbproc, const char *fmt,...)
printf-like way to form SQL to send to the server.
Definition dblib.c:1353
RETCODE dbdatecrack(DBPROCESS *dbproc, DBDATEREC *di, DBDATETIME *dt)
Break a DBDATETIME value into useful pieces.
Definition dblib.c:5889
RETCODE dbresults(DBPROCESS *dbproc)
Set up query results.
Definition dblib.c:1713
RETCODE dbwritetext(DBPROCESS *dbproc, char *objname, DBBINARY *textptr, DBTINYINT textptrlen, DBBINARY *timestamp, DBBOOL log, DBINT size, BYTE *text)
Send text or image data to the server.
Definition dblib.c:6636
RETCODE dbcanquery(DBPROCESS *dbproc)
Cancel the query currently being retrieved, discarding all pending rows.
Definition dblib.c:6073
RETCODE dbinit(void)
Initialize db-lib.
Definition dblib.c:668
DBINT dbvarylen(DBPROCESS *dbproc, int column)
Determine whether a column can vary in size.
Definition dblib.c:3235
RETCODE dbcancel(DBPROCESS *dbproc)
Cancel the current command batch.
Definition dblib.c:3413
RETCODE dbsetlogintime(int seconds)
Set maximum seconds db-lib waits for a server response to a login attempt.
Definition dblib.c:4281
RETCODE dbgetrow(DBPROCESS *dbproc, DBINT row)
Read a row from the row buffer.
Definition dblib.c:1949
int dbcoltype(DBPROCESS *dbproc, int column)
Get the datatype of a regular result set column.
Definition dblib.c:2987
void dbsetifile(char *filename)
set name and location of the interfaces file FreeTDS should use to look up a servername.
Definition dblib.c:2730
RETCODE dbuse(DBPROCESS *dbproc, const char *name)
Change current database.
Definition dblib.c:1464
int dbnumalts(DBPROCESS *dbproc, int computeid)
Get count of columns in a compute row.
Definition dblib.c:4982
BOOL dbiscount(DBPROCESS *dbproc)
Indicates whether or not the count returned by dbcount is real (Microsoft-compatibility feature).
Definition dblib.c:2820
int dbgettime(void)
Get maximum seconds db-lib waits for a server response to query.
Definition dblib.c:4265
RETCODE dbmoretext(DBPROCESS *dbproc, DBINT size, const BYTE text[])
Send chunk of a text/image value to the server.
Definition dblib.c:6774
const char * dbprtype(int token)
Print a token value's name to a buffer.
Definition dblib.c:6489
char * dbcolsource(DBPROCESS *dbproc, int colnum)
Get base database column name for a result set column.
Definition dblib.c:3161
char * dbchange(DBPROCESS *dbprocess)
See if a command caused the current database to change.
Definition dblib.c:7031
const char * dbacolname(DBPROCESS *dbproc, int computeid, int column)
Return name of a computed result column.
Definition dblib.c:1917
RETCODE dbnullbind(DBPROCESS *dbproc, int column, DBINT *indicator)
Tie a null-indicator to a regular result column.
Definition dblib.c:2756
RETCODE dbbind(DBPROCESS *dbproc, int column, int vartype, DBINT varlen, BYTE *varaddr)
Tie a host variable to a resultset column.
Definition dblib.c:2653
RETCODE dbcmd(DBPROCESS *dbproc, const char cmdstring[])
Append SQL to the command buffer.
Definition dblib.c:1392
DBINT dbcollen(DBPROCESS *dbproc, int column)
Get size of a regular result column.
Definition dblib.c:3186
DBINT dbconvert_ps(DBPROCESS *dbprocess, int srctype, const BYTE *src, DBINT srclen, int desttype, BYTE *dest, DBINT destlen, DBTYPEINFO *typeinfo)
Convert one datatype to another.
Definition dblib.c:2319
char * dbgetchar(DBPROCESS *dbprocess, int n)
Get address of a position in the command buffer.
Definition dblib.c:6352
RETCODE dbanullbind(DBPROCESS *dbprocess, int computeid, int column, DBINT *indicator)
Tie a null-indicator to a compute result column.
Definition dblib.c:2792
RETCODE dbclropt(DBPROCESS *dbproc, int option, const char param[])
Reset an option.
Definition dblib.c:6137
DBINT dbcount(DBPROCESS *dbproc)
Get count of rows processed.
Definition dblib.c:2840
int dbaltop(DBPROCESS *dbproc, int computeid, int column)
Get aggregation operator for a compute column.
Definition dblib.c:4486
RETCODE dbtablecolinfo(DBPROCESS *dbproc, DBINT column, DBCOL *pdbcol)
describe table column attributes with a single call (Freetds-only API function modelled on dbcolinfo)
Definition dblib.c:6506
DBINT dbaltlen(DBPROCESS *dbproc, int computeid, int column)
Get size of data in compute column.
Definition dblib.c:7181
RETCODE dbsetopt(DBPROCESS *dbproc, int option, const char *char_param, int int_param)
Set db-lib or server option.
Definition dblib.c:4513
void dbprhead(DBPROCESS *dbproc)
Print result set headings to stdout.
Definition dblib.c:4001
RETCODE dbsetlversion(LOGINREC *login, BYTE version)
Set TDS version for future connections.
Definition dblib.c:960
RETCODE dbprrow(DBPROCESS *dbproc)
Print a result set to stdout.
Definition dblib.c:3559
char * dbname(DBPROCESS *dbproc)
Get name of current database.
Definition dblib.c:7051
int dbalttype(DBPROCESS *dbproc, int computeid, int column)
Get datatype for a compute column.
Definition dblib.c:4382
RETCODE dbsprhead(DBPROCESS *dbproc, char *buffer, DBINT buf_len)
Print result set headings to a buffer.
Definition dblib.c:3937
RETCODE dbsqlexec(DBPROCESS *dbproc)
send the SQL command to the server and wait for an answer.
Definition dblib.c:1438
DBBOOL dbwillconvert(int srctype, int desttype)
Test whether or not a datatype can be converted to another datatype.
Definition dblib.c:2890
DBINT dbcolutype(DBPROCESS *dbprocess, int column)
Get user-defined datatype of a regular result column.
Definition dblib.c:3010
int dbstrbuild(DBPROCESS *dbproc, char *charbuf, int bufsize, char *text, char *formats,...)
Build a printable string from text containing placeholders for variables.
Definition dblib.c:7344
EHANDLEFUNC dberrhandle(EHANDLEFUNC handler)
Set an error handler, for messages from db-lib.
Definition dblib.c:5163
RETCODE dbsetversion(DBINT version)
Specify a db-lib version level.
Definition dblib.c:6018
int dbgetpacket(DBPROCESS *dbproc)
Get TDS packet size for the connection.
Definition dblib.c:4117
void dbrecftos(const char filename[])
Record to a file all SQL commands sent to the server.
Definition dblib.c:6809
BYTE * dbgetuserdata(DBPROCESS *dbproc)
Get address of user-allocated data from a DBPROCESS.
Definition dblib.c:6000
void dbsetuserdata(DBPROCESS *dbproc, BYTE *ptr)
Associate client-allocated (and defined) data with a DBPROCESS.
Definition dblib.c:5982
DBINT dbprcollen(DBPROCESS *dbproc, int column)
Get size of a result column needed to print column.
Definition dblib.c:3209
void dbexit(void)
Close server connections and free all related structures.
Definition dblib.c:1571
void dbloginfree(LOGINREC *login)
free the LOGINREC
Definition dblib.c:746
RETCODE dbmorecmds(DBPROCESS *dbproc)
See if more commands are to be processed.
Definition dblib.c:6279
DBBOOL dbisopt(DBPROCESS *dbproc, int option, const char param[])
Get value of an option.
Definition dblib.c:6205
int dbnumcompute(DBPROCESS *dbprocess)
Get count of COMPUTE clauses for a result set.
Definition dblib.c:5015
RETCODE dbsqlsend(DBPROCESS *dbproc)
Transmit the command buffer to the server.
Definition dblib.c:7087
RETCODE dbsprline(DBPROCESS *dbproc, char *buffer, DBINT buf_len, DBCHAR line_char)
Get formatted string for underlining dbsprhead() column names.
Definition dblib.c:3879
const char * dbversion(void)
See which version of db-lib is in use.
Definition dblib.c:6884
RETCODE dbsafestr(DBPROCESS *dbproc, const char *src, DBINT srclen, char *dest, DBINT destlen, int quotetype)
safely quotes character values in SQL text.
Definition dblib.c:6428
int dbaltcolid(DBPROCESS *dbproc, int computeid, int column)
Get column ID of a compute column.
Definition dblib.c:4326
RETCODE dbanydatecrack(DBPROCESS *dbproc, DBDATEREC2 *di, int type, const void *data)
Break any kind of date or time value into useful pieces.
Definition dblib.c:5910
RETCODE dbsettime(int seconds)
Set maximum seconds db-lib waits for a server response to query.
Definition dblib.c:4234
int dbnumcols(DBPROCESS *dbproc)
Return number of regular columns in a result set.
Definition dblib.c:1867
int dbgetmaxprocs(void)
get maximum simultaneous connections db-lib will open to the server.
Definition dblib.c:4213
DBBINARY * dbtxptr(DBPROCESS *dbproc, int column)
Get text pointer for a column in the current row.
Definition dblib.c:6599
MHANDLEFUNC dbmsghandle(MHANDLEFUNC handler)
Set a message handler, for messages from the server.
Definition dblib.c:5182
STATUS dbreadtext(DBPROCESS *dbproc, void *buf, DBINT bufsize)
Fetch part of a text or image value from the server.
Definition dblib.c:6705
RETCODE dbsqlok(DBPROCESS *dbproc)
Wait for results of a query from the server.
Definition dblib.c:4856
DBINT dbdatlen(DBPROCESS *dbproc, int column)
Get size of current row's data in a regular result column.
Definition dblib.c:3343
STATUS dbsetrow(DBPROCESS *dbprocess, DBINT row)
Make a buffered row "current" without fetching it into bound variables.
Definition dblib.c:2064
void dbclose(DBPROCESS *dbproc)
Close a connection to the server and free associated resources.
Definition dblib.c:1504
RETCODE dbstrcpy(DBPROCESS *dbproc, int start, int numbytes, char *dest)
Get a copy of a chunk of the command buffer.
Definition dblib.c:6384
DBINT dbaltutype(DBPROCESS *dbproc, int computeid, int column)
Get user-defined datatype of a compute column.
Definition dblib.c:7158
RETCODE dbsetmaxprocs(int maxprocs)
Set maximum simultaneous connections db-lib will open to the server.
Definition dblib.c:4141
RETCODE dbspr1row(DBPROCESS *dbproc, char *buffer, DBINT buf_len)
Print a regular result row to a buffer.
Definition dblib.c:3476
RETCODE dbaltbind(DBPROCESS *dbprocess, int computeid, int column, int vartype, DBINT varlen, BYTE *varaddr)
Bind a compute column to a program variable.
Definition dblib.c:4411
DBINT dbretstatus(DBPROCESS *dbproc)
Fetch status value returned by query or remote procedure call.
Definition dblib.c:4716
RETCODE dbrpcinit(DBPROCESS *dbproc, const char rpcname[], DBSMALLINT options)
Initialize a remote procedure call.
Definition rpc.c:72
BYTE * dbretdata(DBPROCESS *dbproc, int retnum)
Get value of an output parameter filled by a stored procedure.
Definition dblib.c:4795
char * dbretname(DBPROCESS *dbproc, int retnum)
Get name of an output parameter filled by a stored procedure.
Definition dblib.c:4766
DBBOOL dbhasretstat(DBPROCESS *dbproc)
Determine if query generated a return status number.
Definition dblib.c:4692
int dbrettype(DBPROCESS *dbproc, int retnum)
Get datatype of a stored procedure's return parameter.
Definition dblib.c:6308
int dbretlen(DBPROCESS *dbproc, int retnum)
Get size of an output parameter filled by a stored procedure.
Definition dblib.c:4821
RETCODE dbrpcparam(DBPROCESS *dbproc, const char paramname[], BYTE status, int type, DBINT maxlen, DBINT datalen, BYTE *value)
Add a parameter to a remote procedure call.
Definition rpc.c:155
RETCODE dbrpcsend(DBPROCESS *dbproc)
Execute the procedure and free associated memory.
Definition rpc.c:281
int dbnumrets(DBPROCESS *dbproc)
Get count of output parameters filled by a stored procedure.
Definition dblib.c:4734
RETCODE bcp_colfmt(DBPROCESS *dbproc, int host_column, int host_type, int host_prefixlen, DBINT host_collen, const BYTE *host_term, int host_termlen, int colnum)
Specify the format of a datafile prior to writing to a table.
Definition bcp.c:377
DBBOOL bcp_getl(LOGINREC *login)
See if BCP_SETL() was used to set the LOGINREC for BCP work.
Definition bcp.c:710
RETCODE bcp_control(DBPROCESS *dbproc, int field, DBINT value)
Set BCP options for uploading a datafile.
Definition bcp.c:546
RETCODE bcp_columns(DBPROCESS *dbproc, int host_colcount)
Indicate how many columns are to be found in the datafile.
Definition bcp.c:301
RETCODE bcp_colptr(DBPROCESS *dbproc, BYTE *colptr, int table_column)
Override bcp_bind() by pointing to a different host variable.
Definition bcp.c:674
RETCODE bcp_bind(DBPROCESS *dbproc, BYTE *varaddr, int prefixlen, DBINT varlen, BYTE *terminator, int termlen, int type, int table_column)
Bind a program host variable to a database column.
Definition bcp.c:2083
RETCODE bcp_exec(DBPROCESS *dbproc, DBINT *rows_copied)
Write a datafile to a table.
Definition bcp.c:1621
DBINT bcp_done(DBPROCESS *dbproc)
Conclude the transfer of data from program variables.
Definition bcp.c:2041
RETCODE bcp_readfmt(DBPROCESS *dbproc, const char filename[])
Read a format definition file.
Definition bcp.c:1682
DBINT bcp_batch(DBPROCESS *dbproc)
Commit a set of rows to the table.
Definition bcp.c:2014
RETCODE bcp_init(DBPROCESS *dbproc, const char *tblname, const char *hfile, const char *errfile, int direction)
Prepare for bulk copy operation on a table.
Definition bcp.c:167
RETCODE bcp_collen(DBPROCESS *dbproc, DBINT varlen, int table_column)
Set the length of a host variable to be written to a table.
Definition bcp.c:267
RETCODE bcp_sendrow(DBPROCESS *dbproc)
Write data in host variables to the table.
Definition bcp.c:1384
RETCODE bcp_colfmt_ps(DBPROCESS *dbproc, int host_column, int host_type, int host_prefixlen, DBINT host_collen, BYTE *host_term, int host_termlen, int colnum, DBTYPEINFO *typeinfo)
Specify the format of a host file for bulk copy purposes, with precision and scale support for numeri...
Definition bcp.c:509
RETCODE bcp_options(DBPROCESS *dbproc, int option, BYTE *value, int valuelen)
Set "hints" for uploading a file.
Definition bcp.c:624
RETCODE dbmny4zero(DBPROCESS *dbproc, DBMONEY4 *dest)
Zero a DBMONEY4 value.
Definition dblib.c:5612
RETCODE dbmny4add(DBPROCESS *dbproc, DBMONEY4 *m1, DBMONEY4 *m2, DBMONEY4 *sum)
Add two DBMONEY4 values.
Definition dblib.c:5635
int dbmny4cmp(DBPROCESS *dbproc, DBMONEY4 *m1, DBMONEY4 *m2)
Compare two DBMONEY4 values.
Definition dblib.c:5754
RETCODE dbmnymaxpos(DBPROCESS *dbproc, DBMONEY *dest)
Get maximum positive DBMONEY value supported.
Definition dblib.c:5387
RETCODE dbmny4minus(DBPROCESS *dbproc, DBMONEY4 *src, DBMONEY4 *dest)
Negate a DBMONEY4 value.
Definition dblib.c:5588
RETCODE dbmnyminus(DBPROCESS *dbproc, DBMONEY *src, DBMONEY *dest)
Negate a DBMONEY value.
Definition dblib.c:5561
RETCODE dbmny4sub(DBPROCESS *dbproc, DBMONEY4 *m1, DBMONEY4 *m2, DBMONEY4 *diff)
Subtract two DBMONEY4 values.
Definition dblib.c:5666
RETCODE dbmnyzero(DBPROCESS *dbproc, DBMONEY *dest)
Set a DBMONEY value to zero.
Definition dblib.c:5366
RETCODE dbmnycopy(DBPROCESS *dbproc, DBMONEY *src, DBMONEY *dest)
Copy a DBMONEY value.
Definition dblib.c:6052
RETCODE dbmny4copy(DBPROCESS *dbprocess, DBMONEY4 *m1, DBMONEY4 *m2)
Copy a DBMONEY4 value.
Definition dblib.c:5782
RETCODE dbmnymaxneg(DBPROCESS *dbproc, DBMONEY *dest)
Get maximum negative DBMONEY value supported.
Definition dblib.c:5408
RETCODE dbmnydec(DBPROCESS *dbproc, DBMONEY *mnyptr)
Subtract $0.0001 from a DBMONEY value.
Definition dblib.c:5533
RETCODE dbmnyinc(DBPROCESS *dbproc, DBMONEY *mnyptr)
Add $0.0001 to a DBMONEY value.
Definition dblib.c:5505
int dbmnycmp(DBPROCESS *dbproc, DBMONEY *m1, DBMONEY *m2)
Compare two DBMONEY values.
Definition dblib.c:5308
int dbdatecmp(DBPROCESS *dbproc, DBDATETIME *d1, DBDATETIME *d2)
Compare DBDATETIME values, similar to strcmp(3).
Definition dblib.c:5807
const char * dbmonthname(DBPROCESS *dbproc, char *language, int monthnum, DBBOOL shortform)
Get name of a month, in some human language.
Definition dblib.c:7002
int dbcurcmd(DBPROCESS *dbproc)
Get number of the row just returned.
Definition dblib.c:6262
RETCODE dbsetlbool(LOGINREC *login, int value, int which)
Set a boolean value in a LOGINREC structure.
Definition dblib.c:909
DBINT dblastrow(DBPROCESS *dbproc)
Get number of the last row in the row buffer.
Definition dblib.c:7251
RETCODE dbcmdrow(DBPROCESS *dbproc)
See if the current command can return rows.
Definition dblib.c:4302
RETCODE dbsetlshort(LOGINREC *login, int value, int which)
Set an integer value in a LOGINREC structure.
Definition dblib.c:874
RETCODE dbrows(DBPROCESS *dbproc)
Indicate whether a query returned rows.
Definition dblib.c:4076
void dbsetavail(DBPROCESS *dbprocess)
Mark a DBPROCESS as "available".
Definition dblib.c:7319
int dbiowdesc(DBPROCESS *dbproc)
Get file descriptor of the socket used by a DBPROCESS to write data coming to the server....
Definition dblib.c:7291
int dbtds(DBPROCESS *dbprocess)
Get the TDS version in use for dbproc.
Definition dblib.c:6843
DBINT dbcurrow(DBPROCESS *dbproc)
Get number of the row currently being read.
Definition dblib.c:6228
STATUS dbrowtype(DBPROCESS *dbprocess)
Get returned row's type.
Definition dblib.c:6245
int dbiordesc(DBPROCESS *dbproc)
Get file descriptor of the socket used by a DBPROCESS to read data coming from the server....
Definition dblib.c:7275
RETCODE dbsetllong(LOGINREC *login, long value, int which)
Set an integer value in a LOGINREC structure.
Definition dblib.c:837
RETCODE dbsetlname(LOGINREC *login, const char *value, int which)
Set the value of a string in a LOGINREC structure.
Definition dblib.c:768
DBPROCESS * tdsdbopen(LOGINREC *login, const char *server, int msdblib)
Form a connection with the server.
Definition dblib.c:1192
DBBOOL dbdead(DBPROCESS *dbproc)
Check if dbproc is an ex-parrot.
Definition dblib.c:5100
DBINT dbfirstrow(DBPROCESS *dbproc)
See if a server response has arrived.
Definition dblib.c:7236
Definition bsqlodbc.c:100
Definition dbpivot.c:77
Definition dbpivot.c:842
Definition dblib.h:44
Definition dblib.h:123
Definition sybdb.h:264
Definition sybdb.h:270
Definition sybdb.h:276
Definition sybdb.h:285
Definition sybdb.h:291
Definition sybdb.h:296
Definition sybdb.h:302
Definition sybdb.h:308
DBSMALLINT offset
time offset
Definition sybdb.h:311
DBUBIGINT time
time, 7 digit precision
Definition sybdb.h:309
DBINT date
date, 0 = 1900-01-01
Definition sybdb.h:310
Definition sybdb.h:337
Definition sybdb.h:343
Definition sybdb.h:356
Definition sybdb.h:375
Definition sybdb.h:459
Definition sybdb.h:475
Definition sybdb.h:491
Definition sybdb.h:507