luarocks错误 require ‘luasql.mysql' 报module 'luasql.mysql' not found:

错误:

require 'luasql.mysql'
stdin:1: module 'luasql.mysql' not found:
no field package.preload['luasql.mysql']
no file '/usr/local/share/lua/5.3/luasql/mysql.lua'
no file '/usr/local/share/lua/5.3/luasql/mysql/init.lua'
no file '/usr/local/lib/lua/5.3/luasql/mysql.lua'
no file '/usr/local/lib/lua/5.3/luasql/mysql/init.lua'
no file './luasql/mysql.lua'
no file './luasql/mysql/init.lua'
no file '/usr/local/lib/lua/5.3/luasql/mysql.so'
no file '/usr/local/lib/lua/5.3/loadall.so'
no file './luasql/mysql.so'
no file '/usr/local/lib/lua/5.3/luasql.so'
no file '/usr/local/lib/lua/5.3/loadall.so'
no file './luasql.so'
stack traceback:
[C]: in function 'require'
stdin:1: in main chunk
[C]: in ?

环境: ubuntu 已安装lua,未安装mysql

解决方案

一、先安装mysql

Ubuntu上安装MySQL非常简单只需要几条命令就可以完成。

1. sudo apt-get install mysql-server

2. apt-get isntall mysql-client

3.  sudo apt-get install libmysqlclient-dev

参考链接

http://www.linuxidc.com/Linux/2016-07/133128.htm

二 安装luasql-mysql

luarocks install luasql-mysql

参考链接 http://www.runoob.com/lua/lua-database-access.html

三 安装luasql-mysql 出错

Error: Could not find header file for MYSQL
No file mysql.h in /usr/local/mysql
You may have to install MYSQL in your system and/or pass MYSQL_DIR or MYSQL_INCDIR to the luarocks command.
Example: luarocks install luasql-mysql MYSQL_DIR=/usr/local

解决方法:

在终端执行whereis mysql 找到mysql 的include路径

luarocks install luasql-mysql MYSQL_INCDIR=/usr/include/mysql 

注释:配置自己查到的mysql.h 所在路径

 

转载于:https://www.cnblogs.com/a9999/p/6873868.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Lua 中写入 MySQL,您需要使用 Lua MySQL 驱动程序。目前有多个 MySQL 驱动程序可供选择,如 LuaSQLluasql-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、付费专栏及课程。

余额充值