You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
146 lines
3.9 KiB
146 lines
3.9 KiB
3 years ago
|
/*
|
||
|
* $Id: tpcd.h,v 1.2 2005/01/03 20:08:59 jms Exp $
|
||
|
*
|
||
|
* Revision History
|
||
|
* ===================
|
||
|
* $Log: tpcd.h,v $
|
||
|
* Revision 1.2 2005/01/03 20:08:59 jms
|
||
|
* change line terminations
|
||
|
*
|
||
|
* Revision 1.1.1.1 2004/11/24 23:31:47 jms
|
||
|
* re-establish external server
|
||
|
*
|
||
|
* Revision 1.1.1.1 2003/04/03 18:54:21 jms
|
||
|
* recreation after CVS crash
|
||
|
*
|
||
|
* Revision 1.1.1.1 2003/04/03 18:54:21 jms
|
||
|
* initial checkin
|
||
|
*
|
||
|
*
|
||
|
*/
|
||
|
/*****************************************************************
|
||
|
* Title: tpcd.h for TPC D
|
||
|
*****************************************************************
|
||
|
*/
|
||
|
#define DFLT 0x0001
|
||
|
#define OUTPUT 0x0002
|
||
|
#define EXPLAIN 0x0004
|
||
|
#define DBASE 0x0008
|
||
|
#define VERBOSE 0x0010
|
||
|
#define TIMING 0x0020
|
||
|
#define LOG 0x0040
|
||
|
#define QUERY 0x0080
|
||
|
#define REFRESH 0x0100
|
||
|
#define ANSI 0x0200
|
||
|
#define SEED 0x0400
|
||
|
#define COMMENT 0x0800
|
||
|
#define INIT 0x1000
|
||
|
#define TERMINATE 0x2000
|
||
|
#define DFLT_NUM 0x4000
|
||
|
|
||
|
/*
|
||
|
* general defines
|
||
|
*/
|
||
|
#define VTAG ':' /* flags a variable substitution */
|
||
|
#define ofp stdout /* make the routine a filter */
|
||
|
#define QDIR_TAG "DSS_QUERY" /* variable to point to queries */
|
||
|
#define QDIR_DFLT "." /* and its default */
|
||
|
|
||
|
/*
|
||
|
* database portability defines
|
||
|
*/
|
||
|
#ifdef VECTORWISE
|
||
|
#define GEN_QUERY_PLAN "EXPLAIN"
|
||
|
#define START_TRAN ""
|
||
|
#define END_TRAN "COMMIT;"
|
||
|
#define SET_OUTPUT ""
|
||
|
#define SET_ROWCOUNT "first %d\n"
|
||
|
#define SET_DBASE ""
|
||
|
#endif /* VECTORWISE */
|
||
|
|
||
|
#ifdef DB2
|
||
|
#define GEN_QUERY_PLAN "SET CURRENT EXPLAIN SNAPSHOT ON;"
|
||
|
#define START_TRAN ""
|
||
|
#define END_TRAN "COMMIT WORK;"
|
||
|
#define SET_OUTPUT ""
|
||
|
#define SET_ROWCOUNT "--#SET ROWS_FETCH %d\n"
|
||
|
#define SET_DBASE "CONNECT TO %s ;\n"
|
||
|
#endif
|
||
|
|
||
|
#ifdef INFORMIX
|
||
|
#define GEN_QUERY_PLAN "SET EXPLAIN ON;"
|
||
|
#define START_TRAN "BEGIN WORK;"
|
||
|
#define END_TRAN "COMMIT WORK;"
|
||
|
#define SET_OUTPUT "OUTPUT TO "
|
||
|
#define SET_ROWCOUNT "FIRST %d"
|
||
|
#define SET_DBASE "database %s ;\n"
|
||
|
#endif
|
||
|
|
||
|
#ifdef ORACLE
|
||
|
#define GEN_QUERY_PLAN ""
|
||
|
#define START_TRAN ""
|
||
|
#define END_TRAN ""
|
||
|
#define SET_OUTPUT ""
|
||
|
#define SET_ROWCOUNT "where rownum <= %d;\n"
|
||
|
#define SET_DBASE ""
|
||
|
#endif
|
||
|
|
||
|
#ifdef SQLSERVER
|
||
|
#define GEN_QUERY_PLAN "set showplan on\nset noexec on\ngo\n"
|
||
|
#define START_TRAN "begin transaction\ngo\n"
|
||
|
#define END_TRAN "commit transaction\ngo\n"
|
||
|
#define SET_OUTPUT ""
|
||
|
#define SET_ROWCOUNT "set rowcount %d\ngo\n\n"
|
||
|
#define SET_DBASE "use %s\ngo\n"
|
||
|
#endif
|
||
|
|
||
|
#ifdef SYBASE
|
||
|
#define GEN_QUERY_PLAN "set showplan on\nset noexec on\ngo\n"
|
||
|
#define START_TRAN "begin transaction\ngo\n"
|
||
|
#define END_TRAN "commit transaction\ngo\n"
|
||
|
#define SET_OUTPUT ""
|
||
|
#define SET_ROWCOUNT "set rowcount %d\ngo\n\n"
|
||
|
#define SET_DBASE "use %s\ngo\n"
|
||
|
#endif
|
||
|
|
||
|
#ifdef TDAT
|
||
|
#define GEN_QUERY_PLAN "EXPLAIN"
|
||
|
#define START_TRAN "BEGIN TRANSACTION"
|
||
|
#define END_TRAN "END TRANSACTION"
|
||
|
#define SET_OUTPUT ".SET FORMAT OFF\n.EXPORT REPORT file="
|
||
|
#define SET_ROWCOUNT ".SET RETCANCEL ON\n.SET RETLIMIT %d\n"
|
||
|
#define SET_DBASE ".LOGON %s\n"
|
||
|
#endif
|
||
|
|
||
|
#ifdef PIVOTAL
|
||
|
#define GEN_QUERY_PLAN ""
|
||
|
#define START_TRAN ""
|
||
|
#define END_TRAN ""
|
||
|
#define SET_OUTPUT ""
|
||
|
#define SET_ROWCOUNT "LIMIT %d;\n"
|
||
|
#define SET_DBASE ""
|
||
|
#endif
|
||
|
|
||
|
#define MAX_VARS 8 /* max number of host vars in any query */
|
||
|
#define QLEN_MAX 2048 /* max length of any query */
|
||
|
#define QUERIES_PER_SET 22
|
||
|
|
||
|
EXTERN int flags;
|
||
|
EXTERN int s_cnt;
|
||
|
EXTERN char *osuff;
|
||
|
EXTERN int stream;
|
||
|
EXTERN char *lfile;
|
||
|
EXTERN char *ifile;
|
||
|
EXTERN char *tfile;
|
||
|
|
||
|
#define MAX_PERMUTE 41
|
||
|
#ifdef DECLARER
|
||
|
int rowcnt_dflt[QUERIES_PER_SET + 1] =
|
||
|
{-1,-1,100,10,-1,-1,-1,-1,-1,-1,20,-1,-1,-1,-1,-1,-1,-1,100,-1,-1,100,-1};
|
||
|
int rowcnt;
|
||
|
#define SEQUENCE(stream, query) permutation[stream % MAX_PERMUTE][query - 1]
|
||
|
#else
|
||
|
extern int rowcnt_dflt[];
|
||
|
extern int rowcnt;
|
||
|
#endif
|