dbd/db2/statement.c

Sat, 13 Jun 2009 08:55:44 +0000

author
nrich@ii.net
date
Sat, 13 Jun 2009 08:55:44 +0000
changeset 31
999ef93f0dbc
parent 30
8599f34c139b
child 32
03ed0ca09837
permissions
-rw-r--r--

* Add `columns' method for DB2 and Oracle statment handles
* Misc cleanup

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
25
2cc3feba9277 Cleanup.
nrich@ii.net
parents: 23
diff changeset
3 #define BIND_BUFFER_SIZE 1024
2cc3feba9277 Cleanup.
nrich@ii.net
parents: 23
diff changeset
4
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
5 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
6 lua_push_type_t lua_type;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
7
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
8 if (len == SQL_NULL_DATA)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
9 return LUA_PUSH_NIL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
10
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
11 switch(db2_type) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
12 case SQL_SMALLINT:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
13 case SQL_INTEGER:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
14 lua_type = LUA_PUSH_INTEGER;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
15 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
16 case SQL_DECIMAL:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
17 lua_type = LUA_PUSH_NUMBER;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
18 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
19 default:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
20 lua_type = LUA_PUSH_STRING;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
21 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
22
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
23 return lua_type;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
24 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
25
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
26 /*
21
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
27 * num_affected_rows = statement:affected()
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
28 */
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
29 static int statement_affected(lua_State *L) {
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
30 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
31 SQLRETURN rc = SQL_SUCCESS;
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
32 SQLINTEGER affected;
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
33
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
34 if (!statement->stmt) {
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
35 luaL_error(L, DBI_ERR_INVALID_STATEMENT);
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
36 }
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
37
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
38 rc = SQLRowCount(statement->stmt, &affected);
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
39
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
40
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
41 lua_pushinteger(L, affected);
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
42
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
43 return 1;
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
44 }
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
45
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
46 /*
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
47 * success = statement:close()
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
48 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
49 static int statement_close(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
50 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
51
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
52 if (statement->stmt) {
28
44b1d78b50f5 Clean up comments.
nrich@ii.net
parents: 27
diff changeset
53 SQLFreeHandle(SQL_HANDLE_STMT, statement->stmt);
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
54
27
1d2369ebee21 Cleanup oracle bind allocations.
nrich@ii.net
parents: 26
diff changeset
55 if (statement->resultset) {
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
56 free(statement->resultset);
27
1d2369ebee21 Cleanup oracle bind allocations.
nrich@ii.net
parents: 26
diff changeset
57 statement->resultset = NULL;
1d2369ebee21 Cleanup oracle bind allocations.
nrich@ii.net
parents: 26
diff changeset
58 }
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
59
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
60 if (statement->bind) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
61 int i;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
62
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
63 for (i = 0; i < statement->num_result_columns; i++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
64 free(statement->bind[i].buffer);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
65 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
66
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
67 free(statement->bind);
27
1d2369ebee21 Cleanup oracle bind allocations.
nrich@ii.net
parents: 26
diff changeset
68 statement->bind = NULL;
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
69 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
70
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
71 statement->num_result_columns = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
72 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
73
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
74 return 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
75 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
76
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
77 /*
30
8599f34c139b Add 'columns' method to statement handles to retrieve column names from a result set
nrich@ii.net
parents: 28
diff changeset
78 * column_names = statement:columns()
8599f34c139b Add 'columns' method to statement handles to retrieve column names from a result set
nrich@ii.net
parents: 28
diff changeset
79 */
31
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
80 static int statement_columns(lua_State *L) {
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
81 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
82
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
83 int i;
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
84 int d;
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
85
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
86 SQLCHAR message[SQL_MAX_MESSAGE_LENGTH + 1];
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
87 SQLCHAR sqlstate[SQL_SQLSTATE_SIZE + 1];
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
88 SQLINTEGER sqlcode;
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
89 SQLSMALLINT length;
30
8599f34c139b Add 'columns' method to statement handles to retrieve column names from a result set
nrich@ii.net
parents: 28
diff changeset
90
31
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
91 SQLRETURN rc = SQL_SUCCESS;
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
92
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
93 if (!statement->resultset || !statement->bind) {
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
94 lua_pushnil(L);
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
95 return 1;
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
96 }
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
97
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
98 d = 1;
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
99 lua_newtable(L);
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
100 for (i = 0; i < statement->num_result_columns; i++) {
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
101 const char *name = strlower(statement->resultset[i].name);
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
102 LUA_PUSH_ARRAY_STRING(d, name);
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
103 }
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
104
999ef93f0dbc * Add `columns' method for DB2 and Oracle statment handles
nrich@ii.net
parents: 30
diff changeset
105 return 1;
30
8599f34c139b Add 'columns' method to statement handles to retrieve column names from a result set
nrich@ii.net
parents: 28
diff changeset
106 }
8599f34c139b Add 'columns' method to statement handles to retrieve column names from a result set
nrich@ii.net
parents: 28
diff changeset
107
8599f34c139b Add 'columns' method to statement handles to retrieve column names from a result set
nrich@ii.net
parents: 28
diff changeset
108 /*
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
109 * success = statement:execute(...)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
110 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
111 static int statement_execute(lua_State *L) {
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
112 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
113 int n = lua_gettop(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
114 int p;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
115 int i;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
116 int errflag = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
117 const char *errstr = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
118 SQLRETURN rc = SQL_SUCCESS;
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
119 unsigned char *buffer = NULL;
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
120 int offset = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
121 resultset_t *resultset = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
122 bindparams_t *bind; /* variable to read the results */
19
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
123 SQLSMALLINT num_params;
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
124
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
125 SQLCHAR message[SQL_MAX_MESSAGE_LENGTH + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
126 SQLCHAR sqlstate[SQL_SQLSTATE_SIZE + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
127 SQLINTEGER sqlcode;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
128 SQLSMALLINT length;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
129
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
130 if (!statement->stmt) {
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 lua_pushstring(L, DBI_ERR_EXECUTE_INVALID);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
133 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
134 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
135
19
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
136 rc = SQLNumParams(statement->stmt, &num_params);
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
137 if (rc != SQL_SUCCESS) {
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
138 SQLGetDiagRec(SQL_HANDLE_STMT, statement->stmt, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
139
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
140 lua_pushboolean(L, 0);
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
141 lua_pushfstring(L, DBI_ERR_PREP_STATEMENT, message);
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
142 return 2;
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
143 }
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
144
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
145 if (num_params != n-1) {
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
146 /*
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
147 * SQLExecute does not handle this condition,
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
148 * and the client library will fill unset params
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
149 * with NULLs
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
150 */
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
151 lua_pushboolean(L, 0);
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
152 lua_pushfstring(L, DBI_ERR_PARAM_MISCOUNT, num_params, n-1);
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
153 return 2;
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
154 }
b5ec612be4da Bugfix - remove unused vars in oracle driver, catch param mismatch in statement:execute()
nrich@ii.net
parents: 17
diff changeset
155
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
156 if (num_params > 0) {
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
157 buffer = (unsigned char *)malloc(sizeof(double) * num_params);
25
2cc3feba9277 Cleanup.
nrich@ii.net
parents: 23
diff changeset
158 }
2cc3feba9277 Cleanup.
nrich@ii.net
parents: 23
diff changeset
159
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
160 for (p = 2; p <= n; p++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
161 int i = p - 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
162 int type = lua_type(L, p);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
163 char err[64];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
164 const char *str = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
165 size_t len = 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
166 double *num;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
167 int *boolean;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
168 const static SQLLEN nullvalue = SQL_NULL_DATA;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
169
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
170 switch(type) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
171 case LUA_TNIL:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
172 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
173 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
174 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
175 case LUA_TNUMBER:
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
176 num = (double *)(buffer + offset);
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
177 *num = lua_tonumber(L, p);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
178 offset += sizeof(double);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
179 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
180 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
181 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
182 case LUA_TSTRING:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
183 str = lua_tolstring(L, p, &len);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
184 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
185 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
186 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
187 case LUA_TBOOLEAN:
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
188 boolean = (int *)(buffer + offset);
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
189 *boolean = lua_toboolean(L, p);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
190 offset += sizeof(int);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
191 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
192 errflag = rc != SQL_SUCCESS && rc != SQL_SUCCESS_WITH_INFO;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
193 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
194 default:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
195 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
196 * Unknown/unsupported value type
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
197 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
198 errflag = 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
199 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
200 errstr = err;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
201 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
202
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
203 if (errflag)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
204 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
205 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
206
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
207 if (errflag) {
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
208 if (buffer)
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
209 free(buffer);
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
210
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
211 lua_pushboolean(L, 0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
212
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
213 if (errstr) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
214 lua_pushfstring(L, DBI_ERR_BINDING_PARAMS, errstr);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
215 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
216 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
217
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
218 lua_pushfstring(L, DBI_ERR_BINDING_PARAMS, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
219 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
220
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
221 return 2;
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 rc = SQLExecute(statement->stmt);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
225 if (rc != SQL_SUCCESS) {
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
226 if (buffer)
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
227 free(buffer);
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
228
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
229 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
230
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
231 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
232 lua_pushfstring(L, DBI_ERR_PREP_STATEMENT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
233 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
234 }
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 * identify the number of output columns
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
238 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
239 rc = SQLNumResultCols(statement->stmt, &statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
240
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
241 if (statement->num_result_columns > 0) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
242 resultset = (resultset_t *)malloc(sizeof(resultset_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
243 memset(resultset, 0, sizeof(resultset_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
244
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
245 bind = (bindparams_t *)malloc(sizeof(bindparams_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
246 memset(bind, 0, sizeof(bindparams_t) * statement->num_result_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
247
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
248 for (i = 0; i < statement->num_result_columns; i++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
249 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
250 * return a set of attributes for a column
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
251 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
252 rc = SQLDescribeCol(statement->stmt,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
253 (SQLSMALLINT)(i + 1),
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
254 resultset[i].name,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
255 sizeof(resultset[i].name),
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
256 &resultset[i].name_len,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
257 &resultset[i].type,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
258 &resultset[i].size,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
259 &resultset[i].scale,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
260 NULL);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
261
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
262 if (rc != SQL_SUCCESS) {
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
263 if (buffer)
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
264 free(buffer);
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
265
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
266 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
267
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
268 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
269 lua_pushfstring(L, DBI_ERR_DESC_RESULT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
270 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
271 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
272
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
273 bind[i].buffer_len = resultset[i].size+1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
274
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
275 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
276 *allocate memory to bind a column
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
277 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
278 bind[i].buffer = (SQLCHAR *)malloc((int)bind[i].buffer_len);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
279
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
280 rc = SQLBindCol(statement->stmt,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
281 (SQLSMALLINT)(i + 1),
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
282 SQL_C_CHAR,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
283 bind[i].buffer,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
284 bind[i].buffer_len,
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
285 &bind[i].len);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
286
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
287 if (rc != SQL_SUCCESS) {
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
288 if (buffer)
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
289 free(buffer);
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
290
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
291 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
292
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
293 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
294 lua_pushfstring(L, DBI_ERR_ALLOC_RESULT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
295 return 2;
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 statement->resultset = resultset;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
300 statement->bind = bind;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
301 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
302
26
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
303 if (buffer)
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
304 free(buffer);
cf847efefdb5 Bugfix - fix allocation bugs
nrich@ii.net
parents: 25
diff changeset
305
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
306 lua_pushboolean(L, 1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
307 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
308 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
309
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
310 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
311 * must be called after an execute
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
312 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
313 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
314 int i;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
315 int d;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
316
23
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
317 SQLCHAR message[SQL_MAX_MESSAGE_LENGTH + 1];
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
318 SQLCHAR sqlstate[SQL_SQLSTATE_SIZE + 1];
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
319 SQLINTEGER sqlcode;
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
320 SQLSMALLINT length;
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
321
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
322 SQLRETURN rc = SQL_SUCCESS;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
323
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
324 if (!statement->resultset || !statement->bind) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
325 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
326 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
327 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
328
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
329 /* fetch each row, and display */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
330 rc = SQLFetch(statement->stmt);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
331 if (rc == SQL_NO_DATA_FOUND) {
23
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
332 SQLFreeStmt(statement->stmt, SQL_RESET_PARAMS);
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
333 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
334 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
335 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
336
23
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
337 if (rc != SQL_SUCCESS) {
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
338 SQLGetDiagRec(SQL_HANDLE_STMT, statement->stmt, 1, sqlstate, &sqlcode, message, SQL_MAX_MESSAGE_LENGTH + 1, &length);
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
339
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
340 luaL_error(L, DBI_ERR_FETCH_FAILED, message);
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
341 }
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
342
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
343 d = 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
344 lua_newtable(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
345 for (i = 0; i < statement->num_result_columns; i++) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
346 lua_push_type_t lua_push = db2_to_lua_push(statement->resultset[i].type, statement->bind[i].len);
23
a4825c3e65e9 Bugfix: memory corruption possible after reallocs. Using a static buffer instead. Will need to check for overflows on static buffer.
nrich@ii.net
parents: 21
diff changeset
347 const char *name = strlower(statement->resultset[i].name);
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
348 double val;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
349 char *value = (char *)statement->bind[i].buffer;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
350
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
351 switch (lua_push) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
352 case LUA_PUSH_NIL:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
353 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
354 LUA_PUSH_ATTRIB_NIL(name);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
355 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
356 LUA_PUSH_ARRAY_NIL(d);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
357 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
358 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
359 case LUA_PUSH_INTEGER:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
360 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
361 LUA_PUSH_ATTRIB_INT(name, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
362 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
363 LUA_PUSH_ARRAY_INT(d, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
364 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
365 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
366 case LUA_PUSH_NUMBER:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
367 val = strtod(value, NULL);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
368
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
369 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
370 LUA_PUSH_ATTRIB_FLOAT(name, val);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
371 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
372 LUA_PUSH_ARRAY_FLOAT(d, val);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
373 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
374 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
375 case LUA_PUSH_BOOLEAN:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
376 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
377 LUA_PUSH_ATTRIB_BOOL(name, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
378 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
379 LUA_PUSH_ARRAY_BOOL(d, atoi(value));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
380 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
381 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
382 case LUA_PUSH_STRING:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
383 if (named_columns) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
384 LUA_PUSH_ATTRIB_STRING(name, value);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
385 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
386 LUA_PUSH_ARRAY_STRING(d, value);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
387 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
388 break;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
389 default:
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
390 luaL_error(L, DBI_ERR_UNKNOWN_PUSH);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
391 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
392 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
393
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
394 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
395 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
396
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
397
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
398 static int next_iterator(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
399 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
400 int named_columns = lua_toboolean(L, lua_upvalueindex(2));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
401
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
402 return statement_fetch_impl(L, statement, named_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
403 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
404
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
405 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
406 * table = statement:fetch(named_indexes)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
407 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
408 static int statement_fetch(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
409 statement_t *statement = (statement_t *)luaL_checkudata(L, 1, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
410 int named_columns = lua_toboolean(L, 2);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
411
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
412 return statement_fetch_impl(L, statement, named_columns);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
413 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
414
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
415 /*
21
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
416 * num_rows = statement:rowcount()
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
417 */
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
418 static int statement_rowcount(lua_State *L) {
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
419 luaL_error(L, DBI_ERR_NOT_IMPLEMENTED, DBD_DB2_STATEMENT, "rowcount");
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
420
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
421 return 0;
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
422 }
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
423
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
424 /*
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
425 * iterfunc = statement:rows(named_indexes)
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
426 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
427 static int statement_rows(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
428 if (lua_gettop(L) == 1) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
429 lua_pushvalue(L, 1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
430 lua_pushboolean(L, 0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
431 } else {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
432 lua_pushvalue(L, 1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
433 lua_pushboolean(L, lua_toboolean(L, 2));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
434 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
435
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
436 lua_pushcclosure(L, next_iterator, 2);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
437 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
438 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
439
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
440 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
441 * __gc
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
442 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
443 static int statement_gc(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
444 /* always free the handle */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
445 statement_close(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
446
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
447 return 0;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
448 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
449
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
450 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
451 SQLRETURN rc = SQL_SUCCESS;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
452 statement_t *statement = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
453 SQLHANDLE stmt;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
454
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
455 SQLCHAR message[SQL_MAX_MESSAGE_LENGTH + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
456 SQLCHAR sqlstate[SQL_SQLSTATE_SIZE + 1];
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
457 SQLINTEGER sqlcode;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
458 SQLSMALLINT length;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
459
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
460 rc = SQLAllocHandle(SQL_HANDLE_STMT, conn->db2, &stmt);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
461 if (rc != SQL_SUCCESS) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
462 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
463
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
464 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
465 lua_pushfstring(L, DBI_ERR_ALLOC_STATEMENT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
466 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
467 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
468
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
469 /*
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
470 * turn off deferred prepare
21
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
471 * statements will be sent to the server at prepare time,
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
472 * and therefore we can catch errors now rather
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
473 * than at execute time
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
474 */
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
475 rc = SQLSetStmtAttr(stmt,SQL_ATTR_DEFERRED_PREPARE,(SQLPOINTER)SQL_DEFERRED_PREPARE_OFF,0);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
476
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
477 rc = SQLPrepare(stmt, (SQLCHAR *)sql_query, SQL_NTS);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
478 if (rc != SQL_SUCCESS) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
479 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
480
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
481 lua_pushnil(L);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
482 lua_pushfstring(L, DBI_ERR_PREP_STATEMENT, message);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
483 return 2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
484 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
485
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
486 statement = (statement_t *)lua_newuserdata(L, sizeof(statement_t));
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
487 statement->stmt = stmt;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
488 statement->db2 = conn->db2;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
489 statement->resultset = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
490 statement->bind = NULL;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
491
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
492 luaL_getmetatable(L, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
493 lua_setmetatable(L, -2);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
494
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
495 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
496 }
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
497
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
498 int dbd_db2_statement(lua_State *L) {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
499 static const luaL_Reg statement_methods[] = {
21
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
500 {"affected", statement_affected},
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
501 {"close", statement_close},
30
8599f34c139b Add 'columns' method to statement handles to retrieve column names from a result set
nrich@ii.net
parents: 28
diff changeset
502 {"columns", statement_columns},
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
503 {"execute", statement_execute},
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
504 {"fetch", statement_fetch},
21
7956401a0c5e Added the statement:affected() and statement:rowcount() methods.
nrich@ii.net
parents: 19
diff changeset
505 {"rowcount", statement_rowcount},
14
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
506 {"rows", statement_rows},
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
507 {NULL, NULL}
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
508 };
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
509
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
510 static const luaL_Reg statement_class_methods[] = {
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
511 {NULL, NULL}
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
512 };
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
513
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
514 luaL_newmetatable(L, DBD_DB2_STATEMENT);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
515 luaL_register(L, 0, statement_methods);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
516 lua_pushvalue(L,-1);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
517 lua_setfield(L, -2, "__index");
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
518
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
519 lua_pushcfunction(L, statement_gc);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
520 lua_setfield(L, -2, "__gc");
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
521
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
522 luaL_register(L, DBD_DB2_STATEMENT, statement_class_methods);
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
523
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
524 return 1;
98192b7d4e89 Add DB2 driver module.
nrich@ii.net
parents:
diff changeset
525 }

mercurial