dbd/db2/statement.c

Sat, 06 Dec 2008 00:32:37 +0000

author
nrich@ii.net
date
Sat, 06 Dec 2008 00:32:37 +0000
changeset 17
21c4feaeafe7
parent 14
98192b7d4e89
child 19
b5ec612be4da
permissions
-rw-r--r--

Added initial Oracle driver support - functionality is complete, but may be too buggy in its current state for any serious use.

14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
1 #include "dbd_db2.h"
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
2
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
3 static lua_push_type_t db2_to_lua_push(unsigned int db2_type, int len) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
4 lua_push_type_t lua_type;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
5
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
6 if (len == SQL_NULL_DATA)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
7 return LUA_PUSH_NIL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
8
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
9 switch(db2_type) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
10 case SQL_SMALLINT:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
11 case SQL_INTEGER:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
12 lua_type = LUA_PUSH_INTEGER;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
13 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
14 case SQL_DECIMAL:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
15 lua_type = LUA_PUSH_NUMBER;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
16 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
17 default:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
18 lua_type = LUA_PUSH_STRING;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
19 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
20
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
21 return lua_type;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
22 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
23
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
24 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
25 * success = statement:close()
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
26 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
27 static int statement_close(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
28 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
29 SQLRETURN rc = SQL_SUCCESS;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
30
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
31 if (statement->stmt) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
32 rc = SQLFreeHandle(SQL_HANDLE_STMT, statement->stmt);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
33
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
34 if (statement->resultset)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
35 free(statement->resultset);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
36
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
37 if (statement->bind) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
38 int i;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
39
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
40 for (i = 0; i < statement->num_result_columns; i++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
41 free(statement->bind[i].buffer);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
42 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
43
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
44 free(statement->bind);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
45 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
46
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
47 statement->num_result_columns = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
48 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
49
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
50 return 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
51 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
52
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
53 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
54 * success = statement:execute(...)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
55 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
56 static int statement_execute(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
57 int n = lua_gettop(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
58 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
59 int p;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
60 int i;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
61 int errflag = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
62 const char *errstr = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
63 SQLRETURN rc = SQL_SUCCESS;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
64 unsigned char *buffer = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
65 int offset = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
66 resultset_t *resultset = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
67 bindparams_t *bind; /* variable to read the results */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
68
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
69 SQLCHAR message[SQL_MAX_MESSAGE_LENGTH + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
70 SQLCHAR sqlstate[SQL_SQLSTATE_SIZE + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
71 SQLINTEGER sqlcode;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
72 SQLSMALLINT length;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
73
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
74 if (!statement->stmt) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
75 lua_pushboolean(L, 0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
76 lua_pushstring(L, DBI_ERR_EXECUTE_INVALID);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
77 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
78 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
79
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
80 for (p = 2; p <= n; p++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
81 int i = p - 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
82 int type = lua_type(L, p);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
83 char err[64];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
84 const char *str = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
85 size_t len = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
86 double *num;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
87 int *boolean;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
88 const static SQLLEN nullvalue = SQL_NULL_DATA;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
89
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
90 switch(type) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
91 case LUA_TNIL:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
92 rc = SQLBindParameter(statement->stmt, i, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, (SQLPOINTER)0, 0, (SQLPOINTER)&nullvalue);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
93 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
94 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
95 case LUA_TNUMBER:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
96 buffer = realloc(buffer, offset + sizeof(double));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
97 num = (double *)buffer + offset;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
98 *num = lua_tonumber(L, p);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
99 offset += sizeof(double);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
100 rc = SQLBindParameter(statement->stmt, i, SQL_PARAM_INPUT, SQL_C_DOUBLE, SQL_DECIMAL, 10, 0, (SQLPOINTER)num, 0, NULL);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
101 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
102 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
103 case LUA_TSTRING:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
104 str = lua_tolstring(L, p, &len);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
105 rc = SQLBindParameter(statement->stmt, i, SQL_PARAM_INPUT, SQL_C_CHAR, SQL_VARCHAR, 0, 0, (SQLPOINTER)str, len, NULL);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
106 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
107 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
108 case LUA_TBOOLEAN:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
109 buffer = realloc(buffer, offset + sizeof(int));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
110 boolean = (int *)buffer + offset;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
111 *boolean = lua_toboolean(L, p);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
112 offset += sizeof(int);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
113 rc = SQLBindParameter(statement->stmt, i, SQL_PARAM_INPUT, SQL_C_LONG, SQL_INTEGER, 0, 0, (SQLPOINTER)boolean, len, NULL);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
114 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
115 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
116 default:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
117 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
118 * Unknown/unsupported value type
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
119 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
120 errflag = 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
121 snprintf(err, sizeof(err)-1, DBI_ERR_BINDING_TYPE_ERR, lua_typename(L, type));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
122 errstr = err;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
123 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
124
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
125 if (errflag)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
126 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
127 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
128
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
129 if (errflag) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
130 realloc(buffer, 0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
131 lua_pushboolean(L, 0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
132
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
133 if (errstr) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
134 lua_pushfstring(L, DBI_ERR_BINDING_PARAMS, errstr);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
135 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
136 SQLGetDiagRec(SQL_HANDLE_STMT, statement->stmt, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
137
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
138 lua_pushfstring(L, DBI_ERR_BINDING_PARAMS, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
139 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
140
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
141 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
142 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
143
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
144 rc = SQLExecute(statement->stmt);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
145 if (rc != SQL_SUCCESS) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
146 SQLGetDiagRec(SQL_HANDLE_STMT, statement->stmt, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
147
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
148 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
149 lua_pushfstring(L, DBI_ERR_PREP_STATEMENT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
150 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
151 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
152
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
153 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
154 * identify the number of output columns
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
155 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
156 rc = SQLNumResultCols(statement->stmt, &statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
157
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
158 if (statement->num_result_columns > 0) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
159 resultset = (resultset_t *)malloc(sizeof(resultset_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
160 memset(resultset, 0, sizeof(resultset_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
161
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
162 bind = (bindparams_t *)malloc(sizeof(bindparams_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
163 memset(bind, 0, sizeof(bindparams_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
164
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
165 for (i = 0; i < statement->num_result_columns; i++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
166 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
167 * return a set of attributes for a column
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
168 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
169 rc = SQLDescribeCol(statement->stmt,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
170 (SQLSMALLINT)(i + 1),
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
171 resultset[i].name,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
172 sizeof(resultset[i].name),
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
173 &resultset[i].name_len,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
174 &resultset[i].type,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
175 &resultset[i].size,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
176 &resultset[i].scale,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
177 NULL);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
178
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
179 if (rc != SQL_SUCCESS) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
180 SQLGetDiagRec(SQL_HANDLE_STMT, statement->stmt, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
181
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
182 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
183 lua_pushfstring(L, DBI_ERR_DESC_RESULT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
184 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
185 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
186
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
187 bind[i].buffer_len = resultset[i].size+1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
188
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
189 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
190 *allocate memory to bind a column
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
191 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
192 bind[i].buffer = (SQLCHAR *)malloc((int)bind[i].buffer_len);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
193
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
194 rc = SQLBindCol(statement->stmt,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
195 (SQLSMALLINT)(i + 1),
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
196 SQL_C_CHAR,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
197 bind[i].buffer,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
198 bind[i].buffer_len,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
199 &bind[i].len);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
200
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
201 if (rc != SQL_SUCCESS) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
202 SQLGetDiagRec(SQL_HANDLE_STMT, statement->stmt, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
203
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
204 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
205 lua_pushfstring(L, DBI_ERR_ALLOC_RESULT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
206 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
207 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
208 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
209
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
210 statement->resultset = resultset;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
211 statement->bind = bind;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
212 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
213
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
214 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
215 * free the buffer with a resize to 0
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
216 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
217 realloc(buffer, 0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
218
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
219 lua_pushboolean(L, 1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
220 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
221 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
222
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
223 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
224 * must be called after an execute
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
225 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
226 static int statement_fetch_impl(lua_State *L, statement_t *statement, int named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
227 int i;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
228 int d;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
229
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
230 SQLRETURN rc = SQL_SUCCESS;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
231
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
232 if (!statement->resultset || !statement->bind) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
233 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
234 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
235 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
236
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
237 /* fetch each row, and display */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
238 rc = SQLFetch(statement->stmt);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
239 if (rc == SQL_NO_DATA_FOUND) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
240 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
241 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
242 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
243
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
244 d = 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
245 lua_newtable(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
246 for (i = 0; i < statement->num_result_columns; i++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
247 lua_push_type_t lua_push = db2_to_lua_push(statement->resultset[i].type, statement->bind[i].len);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
248 const char *name = strlower((char *)statement->resultset[i].name);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
249 double val;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
250 char *value = (char *)statement->bind[i].buffer;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
251
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
252 switch (lua_push) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
253 case LUA_PUSH_NIL:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
254 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
255 LUA_PUSH_ATTRIB_NIL(name);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
256 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
257 LUA_PUSH_ARRAY_NIL(d);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
258 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
259 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
260 case LUA_PUSH_INTEGER:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
261 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
262 LUA_PUSH_ATTRIB_INT(name, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
263 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
264 LUA_PUSH_ARRAY_INT(d, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
265 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
266 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
267 case LUA_PUSH_NUMBER:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
268 val = strtod(value, NULL);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
269
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
270 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
271 LUA_PUSH_ATTRIB_FLOAT(name, val);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
272 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
273 LUA_PUSH_ARRAY_FLOAT(d, val);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
274 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
275 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
276 case LUA_PUSH_BOOLEAN:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
277 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
278 LUA_PUSH_ATTRIB_BOOL(name, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
279 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
280 LUA_PUSH_ARRAY_BOOL(d, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
281 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
282 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
283 case LUA_PUSH_STRING:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
284 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
285 LUA_PUSH_ATTRIB_STRING(name, value);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
286 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
287 LUA_PUSH_ARRAY_STRING(d, value);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
288 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
289 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
290 default:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
291 luaL_error(L, DBI_ERR_UNKNOWN_PUSH);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
292 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
293 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
294
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
295 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
296 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
297
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
298
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
299 static int next_iterator(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
300 statement_t *statement = (statement_t *)luaL_checkudata(L, lua_upvalueindex(1), DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
301 int named_columns = lua_toboolean(L, lua_upvalueindex(2));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
302
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
303 return statement_fetch_impl(L, statement, named_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
304 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
305
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
306 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
307 * table = statement:fetch(named_indexes)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
308 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
309 static int statement_fetch(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
310 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
311 int named_columns = lua_toboolean(L, 2);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
312
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
313 return statement_fetch_impl(L, statement, named_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
314 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
315
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
316 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
317 * iterfunc = statement:rows(named_indexes)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
318 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
319 static int statement_rows(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
320 if (lua_gettop(L) == 1) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
321 lua_pushvalue(L, 1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
322 lua_pushboolean(L, 0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
323 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
324 lua_pushvalue(L, 1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
325 lua_pushboolean(L, lua_toboolean(L, 2));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
326 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
327
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
328 lua_pushcclosure(L, next_iterator, 2);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
329 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
330 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
331
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
332 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
333 * __gc
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
334 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
335 static int statement_gc(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
336 /* always free the handle */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
337 statement_close(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
338
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
339 return 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
340 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
341
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
342 int dbd_db2_statement_create(lua_State *L, connection_t *conn, const char *sql_query) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
343 SQLRETURN rc = SQL_SUCCESS;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
344 statement_t *statement = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
345 SQLHANDLE stmt;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
346
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
347 SQLCHAR message[SQL_MAX_MESSAGE_LENGTH + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
348 SQLCHAR sqlstate[SQL_SQLSTATE_SIZE + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
349 SQLINTEGER sqlcode;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
350 SQLSMALLINT length;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
351
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
352 rc = SQLAllocHandle(SQL_HANDLE_STMT, conn->db2, &stmt);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
353 if (rc != SQL_SUCCESS) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
354 SQLGetDiagRec(SQL_HANDLE_DBC, conn->db2, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
355
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
356 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
357 lua_pushfstring(L, DBI_ERR_ALLOC_STATEMENT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
358 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
359 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
360
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
361 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
362 * turn off deferred prepare
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
363 * statements will be sent to the server at prepare timr,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
364 * and therefor we can catch errors then rather
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
365 * than at execute time
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
366 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
367 rc = SQLSetStmtAttr(stmt,SQL_ATTR_DEFERRED_PREPARE,(SQLPOINTER)SQL_DEFERRED_PREPARE_OFF,0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
368
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
369 rc = SQLPrepare(stmt, (SQLCHAR *)sql_query, SQL_NTS);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
370 if (rc != SQL_SUCCESS) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
371 SQLGetDiagRec(SQL_HANDLE_STMT, stmt, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
372
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
373 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
374 lua_pushfstring(L, DBI_ERR_PREP_STATEMENT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
375 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
376 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
377
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
378 statement = (statement_t *)lua_newuserdata(L, sizeof(statement_t));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
379 statement->stmt = stmt;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
380 statement->db2 = conn->db2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
381 statement->resultset = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
382 statement->bind = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
383
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
384 luaL_getmetatable(L, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
385 lua_setmetatable(L, -2);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
386
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
387 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
388 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
389
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
390 int dbd_db2_statement(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
391 static const luaL_Reg statement_methods[] = {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
392 {"close", statement_close},
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
393 {"execute", statement_execute},
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
394 {"fetch", statement_fetch},
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
395 {"rows", statement_rows},
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
396 {NULL, NULL}
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
397 };
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
398
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
399 static const luaL_Reg statement_class_methods[] = {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
400 {NULL, NULL}
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
401 };
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
402
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
403 luaL_newmetatable(L, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
404 luaL_register(L, 0, statement_methods);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
405 lua_pushvalue(L,-1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
406 lua_setfield(L, -2, "__index");
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
407
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
408 lua_pushcfunction(L, statement_gc);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
409 lua_setfield(L, -2, "__gc");
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
410
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
411 luaL_register(L, DBD_DB2_STATEMENT, statement_class_methods);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
412
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
413 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
414 }

mercurial