1
0
mirror of https://github.com/luapower/mysql.git synced 2025-01-04 07:10:25 +01:00

unimportant

This commit is contained in:
Cosmin Apreutesei 2021-12-05 03:53:30 +02:00
parent 2ce7070da1
commit 53c844a94d
3 changed files with 22 additions and 19 deletions

View File

@ -883,7 +883,8 @@ end
--that's how you have to declare a varchar these days. --that's how you have to declare a varchar these days.
function mysql.char_size(byte_size, collation) function mysql.char_size(byte_size, collation)
charset = collation:match'^[^_]+' charset = collation:match'^[^_]+'
return floor(byte_size / max_char_widths[charset] + .5) local mcw = max_char_widths[charset]
return mcw and floor(byte_size / mcw + .5) or byte_size
end end
--NOTE: MySQL doesn't give enough metadata to generate a form in a UI, --NOTE: MySQL doesn't give enough metadata to generate a form in a UI,
@ -893,7 +894,7 @@ end
local function get_field_packet(buf) local function get_field_packet(buf)
local col = {} local col = {}
local _ = get_name(buf) --always "def" local _ = get_name(buf) --always "def"
col.schema = get_name(buf) col.db = get_name(buf)
col.table_alias = get_name(buf) col.table_alias = get_name(buf)
col.table = get_name(buf) --name of origin table col.table = get_name(buf) --name of origin table
col.name = get_name(buf) --alias column name col.name = get_name(buf) --alias column name
@ -961,6 +962,8 @@ local function get_field_packet(buf)
return col return col
end end
local function tonum(x) return tonumber(x) end
local function recv_field_packets(self, field_count, field_attrs, to_lua) local function recv_field_packets(self, field_count, field_attrs, to_lua)
local fields = {} local fields = {}
to_lua = to_lua or self.to_lua to_lua = to_lua or self.to_lua
@ -968,7 +971,7 @@ local function recv_field_packets(self, field_count, field_attrs, to_lua)
local typ, buf = recv_packet(self) local typ, buf = recv_packet(self)
checkp(self, typ == 'DATA', 'bad packet type') checkp(self, typ == 'DATA', 'bad packet type')
local field = get_field_packet(buf) local field = get_field_packet(buf)
field.to_lua = to_lua or (field.type == 'number' and tonumber or nil) field.to_lua = to_lua or (field.type == 'number' and tonum or nil)
field.index = i field.index = i
fields[i] = field fields[i] = field
fields[field.name] = field fields[field.name] = field
@ -1016,8 +1019,8 @@ function mysql.connect(opt)
local host = opt.host local host = opt.host
local port = opt.port or 3306 local port = opt.port or 3306
mysql.note('connect', 'host=%s:%s user=%s schema=%s', mysql.note('connect', 'host=%s:%s user=%s db=%s',
host, port, opt.user, opt.schema or '') host, port, opt.user, opt.db or '')
local tcp = opt and opt.tcp or require'sock'.tcp local tcp = opt and opt.tcp or require'sock'.tcp
tcp = check_io(self, tcp()) tcp = check_io(self, tcp())
@ -1080,7 +1083,7 @@ function mysql.connect(opt)
buf(23) buf(23)
set_cstring(buf, opt.user or '') set_cstring(buf, opt.user or '')
set_token(buf, opt.password, scramble) set_token(buf, opt.password, scramble)
set_cstring(buf, opt.schema or '') set_cstring(buf, opt.db or '')
send_packet(self, buf) send_packet(self, buf)
local typ, buf = recv_packet(self) local typ, buf = recv_packet(self)
@ -1099,7 +1102,7 @@ function mysql.connect(opt)
end end
self.charset_is_ascii_superset = self.charset and not mb_charsets[self.charset] self.charset_is_ascii_superset = self.charset and not mb_charsets[self.charset]
self.schema = opt.schema self.db = opt.db
self.user = opt.user self.user = opt.user
return self return self
@ -1227,7 +1230,7 @@ local function read_result(self, opt)
end end
local to_lua = col.to_lua local to_lua = col.to_lua
if to_lua then if to_lua then
v = to_lua(v) v = to_lua(v, col)
end end
else else
v = null_value v = null_value
@ -1246,7 +1249,7 @@ local function read_result(self, opt)
if v ~= nil then if v ~= nil then
local to_lua = col.to_lua local to_lua = col.to_lua
if to_lua then if to_lua then
v = to_lua(v) v = to_lua(v, col)
end end
else else
v = null_value v = null_value
@ -1283,13 +1286,13 @@ end
conn.get_collation = protect(get_collation) conn.get_collation = protect(get_collation)
do do
local function pass(self, schema, ret, ...) local function pass(self, db, ret, ...)
if not ret then return nil, ... end if not ret then return nil, ... end
self.schema = schema self.db = db
return ret, ... return ret, ...
end end
function conn:use(schema) function conn:use(db)
return pass(self, schema, self:query('use `' .. schema .. '`')) return pass(self, db, self:query('use `' .. db .. '`'))
end end
end end

View File

@ -16,7 +16,7 @@ assert(mysql.connect{
port = 3306, port = 3306,
user = 'bar', user = 'bar',
password = 'baz', password = 'baz',
schema = 'foo', db = 'foo',
charset = 'utf8mb4', charset = 'utf8mb4',
max_packet_size = 1024 * 1024, max_packet_size = 1024 * 1024,
}) })
@ -50,7 +50,7 @@ The `options` argument is a Lua table holding the following keys:
* `port`: server's port (optional, defaults to 3306). * `port`: server's port (optional, defaults to 3306).
* `user`: user name. * `user`: user name.
* `password`: password (optional). * `password`: password (optional).
* `schema`: the schema to set as current schema (optional). * `db`: the database to set as current database (optional).
* `collation`: the collation used for the connection (`charset` is implied by this). * `collation`: the collation used for the connection (`charset` is implied by this).
* use `'server'` to get the server's collation and charset for the connection. * use `'server'` to get the server's collation and charset for the connection.
* `charset`: the character set used for the connection. * `charset`: the character set used for the connection.
@ -61,7 +61,7 @@ The `options` argument is a Lua table holding the following keys:
"ssl disabled on server" is returned. "ssl disabled on server" is returned.
* `ssl_verify`: if `true`, then verifies the validity of the server SSL * `ssl_verify`: if `true`, then verifies the validity of the server SSL
certificate (default is `false`). certificate (default is `false`).
* `to_lua = f(v) -> v` -- custom value converter (defaults to `mysql.to_lua`). * `to_lua = f(v, col) -> v` -- custom value converter (defaults to `mysql.to_lua`).
### `cn:close() -> true | nil,err` ### `cn:close() -> true | nil,err`
@ -90,7 +90,7 @@ The `options` arg can contain:
(but `#cols` will). (but `#cols` will).
* `to_array = true` -- return an array of values for single-column results. * `to_array = true` -- return an array of values for single-column results.
* `null_value = val` -- value to use for `null` (defaults to `nil`). * `null_value = val` -- value to use for `null` (defaults to `nil`).
* `to_lua = f(v) -> v` -- custom value converter (defaults to `cn.to_lua`). * `to_lua = f(v, col) -> v` -- custom value converter (defaults to `cn.to_lua`).
* `field_attrs = {name -> attr}` -- extra field attributes. * `field_attrs = {name -> attr}` -- extra field attributes.
For queries that return a result set, it returns an array of rows. For queries that return a result set, it returns an array of rows.
@ -113,7 +113,7 @@ if MySQL does not return them.
__NOTE:__ Decimals with up to 15 digits of precision and 64 bit integers __NOTE:__ Decimals with up to 15 digits of precision and 64 bit integers
are converted to Lua numbers by default. That limits the useful range of are converted to Lua numbers by default. That limits the useful range of
integer types to 15 significant digits. If you have other needs, provide integer types to 15 significant digits. If you have other needs, provide
your own `to_lua` (which you can set atmodule, connection and query level, your own `to_lua` (which you can set at module, connection and query level,
and even per field with `field_attrs`). and even per field with `field_attrs`).
### `cn:query(query, [options]) -> res,nil,cols | nil,err,errcode,sqlstate` ### `cn:query(query, [options]) -> res,nil,cols | nil,err,errcode,sqlstate`

View File

@ -11,7 +11,7 @@ sock.run(function()
port = 3307, port = 3307,
user = 'root', user = 'root',
password = 'root', password = 'root',
schema = 'sp', db = 'sp',
collation = 'server', collation = 'server',
}) })