Comparison

util/sql.lua @ 7174:d350e475f94e

util.sql: Raw query debug logging (needs to be explicitly enabled by a plugin)
author Kim Alvefur <zash@zash.se>
date Sun, 21 Feb 2016 19:25:01 +0100
parent 6806:f824057189ed
child 7180:0d7f80263813
comparison
equal deleted inserted replaced
7173:d8c060615aa1 7174:d350e475f94e
145 local result_mt = { __index = { 145 local result_mt = { __index = {
146 affected = function(self) return self.__stmt:affected(); end; 146 affected = function(self) return self.__stmt:affected(); end;
147 rowcount = function(self) return self.__stmt:rowcount(); end; 147 rowcount = function(self) return self.__stmt:rowcount(); end;
148 } }; 148 } };
149 149
150 local function debugquery(where, sql, ...)
151 local i = 0; local a = {...}
152 log("debug", "[%s] %s", where, sql:gsub("%?", function () i = i + 1; local v = a[i]; if type(v) == "string" then v = ("%q"):format(v); end return tostring(v); end));
153 end
154
150 function engine:execute_query(sql, ...) 155 function engine:execute_query(sql, ...)
151 if self.params.driver == "PostgreSQL" then 156 if self.params.driver == "PostgreSQL" then
152 sql = sql:gsub("`", "\""); 157 sql = sql:gsub("`", "\"");
153 end 158 end
154 local stmt = assert(self.conn:prepare(sql)); 159 local stmt = assert(self.conn:prepare(sql));
170 end 175 end
171 engine.insert = engine.execute_update; 176 engine.insert = engine.execute_update;
172 engine.select = engine.execute_query; 177 engine.select = engine.execute_query;
173 engine.delete = engine.execute_update; 178 engine.delete = engine.execute_update;
174 engine.update = engine.execute_update; 179 engine.update = engine.execute_update;
180 local function debugwrap(name, f)
181 return function (self, sql, ...)
182 debugquery(name, sql, ...)
183 return f(self, sql, ...)
184 end
185 end
186 function engine:debug(enable)
187 self._debug = enable;
188 if enable then
189 engine.insert = debugwrap("insert", engine.execute_update);
190 engine.select = debugwrap("select", engine.execute_query);
191 engine.delete = debugwrap("delete", engine.execute_update);
192 engine.update = debugwrap("update", engine.execute_update);
193 else
194 engine.insert = engine.execute_update;
195 engine.select = engine.execute_query;
196 engine.delete = engine.execute_update;
197 engine.update = engine.execute_update;
198 end
199 end
175 function engine:_transaction(func, ...) 200 function engine:_transaction(func, ...)
176 if not self.conn then 201 if not self.conn then
177 local ok, err = self:connect(); 202 local ok, err = self:connect();
178 if not ok then return ok, err; end 203 if not ok then return ok, err; end
179 end 204 end
219 sql = sql:gsub("`([,)])", "`(20)%1"); 244 sql = sql:gsub("`([,)])", "`(20)%1");
220 end 245 end
221 if index.unique then 246 if index.unique then
222 sql = sql:gsub("^CREATE", "CREATE UNIQUE"); 247 sql = sql:gsub("^CREATE", "CREATE UNIQUE");
223 end 248 end
224 --print(sql); 249 if self._debug then
250 debugquery("create", sql);
251 end
225 return self:execute(sql); 252 return self:execute(sql);
226 end 253 end
227 function engine:_create_table(table) 254 function engine:_create_table(table)
228 local sql = "CREATE TABLE `"..table.name.."` ("; 255 local sql = "CREATE TABLE `"..table.name.."` (";
229 for i,col in ipairs(table.c) do 256 for i,col in ipairs(table.c) do
249 sql = sql.. ");" 276 sql = sql.. ");"
250 if self.params.driver == "PostgreSQL" then 277 if self.params.driver == "PostgreSQL" then
251 sql = sql:gsub("`", "\""); 278 sql = sql:gsub("`", "\"");
252 elseif self.params.driver == "MySQL" then 279 elseif self.params.driver == "MySQL" then
253 sql = sql:gsub(";$", (" CHARACTER SET '%s' COLLATE '%s_bin';"):format(self.charset, self.charset)); 280 sql = sql:gsub(";$", (" CHARACTER SET '%s' COLLATE '%s_bin';"):format(self.charset, self.charset));
281 end
282 if self._debug then
283 debugquery("create", sql);
254 end 284 end
255 local success,err = self:execute(sql); 285 local success,err = self:execute(sql);
256 if not success then return success,err; end 286 if not success then return success,err; end
257 for i,v in ipairs(table.__table__) do 287 for i,v in ipairs(table.__table__) do
258 if is_index(v) then 288 if is_index(v) then