1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
|
/*
** Zabbix
** Copyright (C) 2001-2014 Zabbix SIA
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**/
#ifndef ZABBIX_ZBXDB_H
#define ZABBIX_ZBXDB_H
#include "common.h"
#define ZBX_DB_OK 0
#define ZBX_DB_FAIL -1
#define ZBX_DB_DOWN -2
#define ZBX_MAX_SQL_SIZE 262144 /* 256KB */
#if defined(HAVE_IBM_DB2)
# include <sqlcli1.h>
typedef struct
{
SQLHANDLE henv;
SQLHANDLE hdbc;
}
zbx_ibm_db2_handle_t;
# define DB_ROW char **
# define DB_RESULT ZBX_IBM_DB2_RESULT *
# define DBfree_result IBM_DB2free_result
typedef struct
{
SQLHANDLE hstmt;
SQLSMALLINT nalloc;
SQLSMALLINT ncolumn;
DB_ROW values;
DB_ROW values_cli;
SQLINTEGER *values_len;
}
ZBX_IBM_DB2_RESULT;
void IBM_DB2free_result(DB_RESULT result);
int IBM_DB2server_status();
int zbx_ibm_db2_success(SQLRETURN ret);
int zbx_ibm_db2_success_ext(SQLRETURN ret);
void zbx_ibm_db2_log_errors(SQLSMALLINT htype, SQLHANDLE hndl);
#elif defined(HAVE_MYSQL)
# include "mysql.h"
# include "errmsg.h"
# include "mysqld_error.h"
# define DB_ROW MYSQL_ROW
# define DB_RESULT MYSQL_RES *
# define DBfree_result mysql_free_result
#elif defined(HAVE_ORACLE)
# include "oci.h"
typedef struct
{
OCIEnv *envhp;
OCIError *errhp;
OCISvcCtx *svchp;
OCIServer *srvhp;
OCIStmt *stmthp; /* the statement handle for execute operations */
}
zbx_oracle_db_handle_t;
# define DB_ROW char **
# define DB_RESULT ZBX_OCI_DB_RESULT *
# define DBfree_result OCI_DBfree_result
typedef struct
{
OCIStmt *stmthp; /* the statement handle for select operations */
int ncolumn;
DB_ROW values;
ub4 *values_alloc;
OCILobLocator **clobs;
}
ZBX_OCI_DB_RESULT;
void OCI_DBfree_result(DB_RESULT result);
ub4 OCI_DBserver_status();
#elif defined(HAVE_POSTGRESQL)
# include <libpq-fe.h>
# define DB_ROW char **
# define DB_RESULT ZBX_PG_DB_RESULT *
# define DBfree_result PG_DBfree_result
typedef struct
{
PGresult *pg_result;
int row_num;
int fld_num;
int cursor;
DB_ROW values;
}
ZBX_PG_DB_RESULT;
void PG_DBfree_result(DB_RESULT result);
#elif defined(HAVE_SQLITE3)
# include <sqlite3.h>
# define DB_ROW char **
# define DB_RESULT ZBX_SQ_DB_RESULT *
# define DBfree_result SQ_DBfree_result
typedef struct
{
int curow;
char **data;
int nrow;
int ncolumn;
DB_ROW values;
}
ZBX_SQ_DB_RESULT;
void SQ_DBfree_result(DB_RESULT result);
#endif /* HAVE_SQLITE3 */
#ifdef HAVE_SQLITE3
/* we have to put double % here for sprintf */
# define ZBX_SQL_MOD(x, y) #x "%%" #y
#else
# define ZBX_SQL_MOD(x, y) "mod(" #x "," #y ")"
#endif
#ifdef HAVE_MULTIROW_INSERT
# define ZBX_ROW_DL ","
#else
# define ZBX_ROW_DL ";\n"
#endif
int zbx_db_connect(char *host, char *user, char *password, char *dbname, char *dbschema, char *dbsocket, int port);
#ifdef HAVE_SQLITE3
void zbx_create_sqlite3_mutex(const char *dbname);
void zbx_remove_sqlite3_mutex();
#endif
void zbx_db_init(char *dbname);
void zbx_db_close();
int zbx_db_begin();
int zbx_db_commit();
int zbx_db_rollback();
int zbx_db_txn_level();
int zbx_db_txn_error();
#ifdef HAVE_ORACLE
int zbx_db_statement_prepare(const char *sql);
int zbx_db_bind_parameter(int position, void *buffer, unsigned char type);
int zbx_db_statement_execute();
#endif
int zbx_db_vexecute(const char *fmt, va_list args);
DB_RESULT zbx_db_vselect(const char *fmt, va_list args);
DB_RESULT zbx_db_select_n(const char *query, int n);
DB_ROW zbx_db_fetch(DB_RESULT result);
int zbx_db_is_null(const char *field);
#endif
|