Lua连接Mysql

Window 下安装 LuaRocks:https://github.com/keplerproject/luarocks/wiki/Installation-instructions-for-Windows

require "luasql.mysql"

--创建环境对象
env = luasql.mysql()

--连接数据库
conn = env:connect("数据库名","用户名","密码","IP地址",端口)

--设置数据库的编码格式
conn:execute"SET NAMES UTF8"

--执行数据库操作
cur = conn:execute("select * from role")

row = cur:fetch({},"a")

--文件对象的创建
file = io.open("role.txt","w+");

while row do
    var = string.format("%d %s\n", row.id, row.name)

    print(var)

    file:write(var)

    row = cur:fetch(row,"a")
end

file:close()  --关闭文件对象
conn:close()  --关闭数据库连接
env:close()   --关闭数据库环境
要在 Lua 中写入 MySQL,您需要使用 Lua MySQL 驱动程序。目前有多个 MySQL 驱动程序可供选择,如 LuaSQL 和 luasql-mysql 等。在这里,我们以 luasql-mysql 为例。 首先,您需要安装 luasql-mysql 驱动程序。您可以使用 LuaRocks 进行安装,命令如下: ``` luarocks install luasql-mysql ``` 接下来,您可以使用以下代码来连接 MySQL 数据库并写入数据: ```lua local mysql = require "luasql.mysql" -- 连接MySQL 数据库 local env = assert(mysql.mysql()) local conn = assert(env:connect("database_name", "username", "password", "host", port)) -- 写入数据 local query = [[ INSERT INTO table_name (column1, column2, column3) VALUES (?, ?, ?) ]] local stmt = assert(conn:prepare(query)) assert(stmt:execute("value1", "value2", "value3")) -- 关闭连接 stmt:close() conn:close() env:close() ``` 其中,`database_name` 是您要连接的数据库名称,`username` 和 `password` 分别是您的 MySQL 用户名和密码,`host` 是 MySQL 主机名或 IP 地址,`port` 是 MySQL 端口号,通常为 3306。 在 `query` 变量中,您可以编写要执行的 SQL 查询语句。在这里,我们使用了参数化查询来避免 SQL 注入攻击。`stmt:execute()` 方法用于执行 SQL 查询,并将要写入的数据作为参数传递给查询语句。 最后,您需要关闭连接,以释放资源。 注意:在实际应用中,您应该对写入的数据进行验证和过滤,以确保数据的安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值