1
0
mirror of https://github.com/luapower/mysql.git synced 2025-01-07 16:50:24 +01:00

unimportant

This commit is contained in:
Cosmin Apreutesei 2021-04-29 23:06:07 +03:00
parent 5612b97801
commit cb7ae6e888
2 changed files with 24 additions and 98 deletions

View File

@ -510,16 +510,6 @@ function _M.new(self)
end end
function _M.set_timeout(self, timeout)
local sock = self.sock
if not sock then
return nil, "not initialized"
end
return sock:settimeout(timeout)
end
function _M.connect(self, opts) function _M.connect(self, opts)
local sock = self.sock local sock = self.sock
if not sock then if not sock then

View File

@ -1,7 +1,7 @@
## `local mysql = require'mysql_client'` ## `local mysql = require'mysql_client'`
MySQL client protocol MySQL client protocol in Lua. Stolen from OpenResty and modified to work standalone.
## Status ## Status
@ -10,96 +10,37 @@ This library is considered production ready.
## Example ## Example
```lua ```lua
local mysql = require "resty.mysql" local mysql = require'mysql_client'
local db, err = mysql:new() local db = assert(mysql:new())
if not db then
ngx.say("failed to instantiate mysql: ", err)
return
end
db:set_timeout(1000) -- 1 sec assert(db:connect{
host = '127.0.0.1',
-- or connect to a unix domain socket file listened
-- by a mysql server:
-- local ok, err, errcode, sqlstate =
-- db:connect{
-- path = "/path/to/mysql.sock",
-- database = "ngx_test",
-- user = "ngx_test",
-- password = "ngx_test" }
local ok, err, errcode, sqlstate = db:connect{
host = "127.0.0.1",
port = 3306, port = 3306,
database = "ngx_test", database = 'ngx_test',
user = "ngx_test", user = 'ngx_test',
password = "ngx_test", password = 'ngx_test',
charset = "utf8", charset = 'utf8',
max_packet_size = 1024 * 1024, max_packet_size = 1024 * 1024,
} })
if not ok then assert(db:query('drop table if exists cats'))
ngx.say("failed to connect: ", err, ": ", errcode, " ", sqlstate)
return
end
ngx.say("connected to mysql.") local res = assert(db:query('create table cats '
.. '(id serial primary key, '
.. 'name varchar(5))'))
local res, err, errcode, sqlstate = local res = assert(db:query('insert into cats (name) '
db:query("drop table if exists cats") .. 'values (\'Bob\'),(\'\'),(null)'))
if not res then
ngx.say("bad result: ", err, ": ", errcode, ": ", sqlstate, ".")
return
end
res, err, errcode, sqlstate = print(res.affected_rows, ' rows inserted into table cats ',
db:query("create table cats " '(last insert id: ', res.insert_id, ')')
.. "(id serial primary key, "
.. "name varchar(5))")
if not res then
ngx.say("bad result: ", err, ": ", errcode, ": ", sqlstate, ".")
return
end
ngx.say("table cats created.") local res = assert(db:query('select * from cats order by id asc', 10))
res, err, errcode, sqlstate = local cjson = require'cjson'
db:query("insert into cats (name) " print(cjson.encode(res))
.. "values (\'Bob\'),(\'\'),(null)")
if not res then
ngx.say("bad result: ", err, ": ", errcode, ": ", sqlstate, ".")
return
end
ngx.say(res.affected_rows, " rows inserted into table cats ", assert(db:close())
"(last insert id: ", res.insert_id, ")")
-- run a select query, expected about 10 rows in
-- the result set:
res, err, errcode, sqlstate =
db:query("select * from cats order by id asc", 10)
if not res then
ngx.say("bad result: ", err, ": ", errcode, ": ", sqlstate, ".")
return
end
local cjson = require "cjson"
ngx.say("result: ", cjson.encode(res))
-- put it into the connection pool of size 100,
-- with 10 seconds max idle timeout
local ok, err = db:set_keepalive(10000, 100)
if not ok then
ngx.say("failed to set keepalive: ", err)
return
end
-- or just close the connection right away:
-- local ok, err = db:close()
-- if not ok then
-- ngx.say("failed to close: ", err)
-- return
-- end
``` ```
## API ## API
@ -134,11 +75,6 @@ The `options` argument is a Lua table holding the following keys:
* `compact_arrays`: `true` to use array-of-arrays structure for the result set, * `compact_arrays`: `true` to use array-of-arrays structure for the result set,
rather than the default array-of-hashes structure. rather than the default array-of-hashes structure.
### `db:set_timeout(time)`
Sets the timeout (in ms) protection for subsequent operations,
including the `connect` method.
### `db:close() -> 1 | nil,err` ### `db:close() -> 1 | nil,err`
Closes the current mysql connection and returns the status. Closes the current mysql connection and returns the status.