在Lua用luasql-sqlite3库访问SQLite数据库

用luarocks包管理器安装,注意库名是luasql-sqlite3,另一个相近的库luasql-sqlite会报缺少sqlite.h头文件错误。

复制代码
luarocks install luasql-sqlite
Installing https://luarocks.org/luasql-sqlite-2.6.0-3.src.rock

Error: Could not find header file for SQLITE
  No file sqlite.h in /usr/local/include
  No file sqlite.h in /usr/include
  No file sqlite.h in /include
You may have to install SQLITE in your system and/or pass SQLITE_DIR or SQLITE_INCDIR to the luarocks command.
Example: luarocks install luasql-sqlite SQLITE_DIR=/usr/local

whereis sqlite.h
sqlite.h:
whereis sqlite3.h
sqlite3.h: /usr/include/sqlite3.h

安装,卡在克隆阶段,从现象看是连接github超时

复制代码
luarocks install luasql-sqlite3
Installing https://luarocks.org/luasql-sqlite3-2.7.0-1.rockspec
Cloning into 'luasql'...
^C
Error: Failed cloning git repository.

手工下载包规格脚本

复制代码
wget  https://luarocks.org/luasql-sqlite3-2.7.0-1.rockspec
--2025-10-29 12:35:35--  https://luarocks.org/luasql-sqlite3-2.7.0-1.rockspec
Resolving luarocks.org (luarocks.org)... 45.33.61.132
Connecting to luarocks.org (luarocks.org)|45.33.61.132|:443... connected.
HTTP request sent, awaiting response... 200 OK
Length: 894 [text/x-rockspec]
Saving to: 'luasql-sqlite3-2.7.0-1.rockspec'

luasql-sqlite3-2.7.0-1.rocksp 100%[=================================================>]     894  --.-KB/s    in 0s

2025-10-29 12:35:36 (2.73 MB/s) - 'luasql-sqlite3-2.7.0-1.rockspec' saved [894/894]

内容如下

复制代码
package = "LuaSQL-SQLite3"
version = "2.7.0-1"
source = {
  url = "git+https://github.com/lunarmodules/luasql.git",
  branch = "2.7.0",
}
description = {
   summary = "Database connectivity for Lua (SQLite3 driver)",
   detailed = [[
      LuaSQL is a simple interface from Lua to a DBMS. It enables a
      Lua program to connect to databases, execute arbitrary SQL statements
      and retrieve results in a row-by-row cursor fashion.
   ]],
   license = "MIT/X11",
   homepage = "https://lunarmodules.github.io/luasql/"
}
dependencies = {
   "lua >= 5.1"
}
external_dependencies = {
   SQLITE = {
      header = "sqlite3.h"
   }
}
build = {
   type = "builtin",
   modules = {
     ["luasql.sqlite3"] = {
       sources = { "src/luasql.c", "src/ls_sqlite3.c" },
       libraries = { "sqlite3" },
       incdirs = { "$(SQLITE_INCDIR)" },
       libdirs = { "$(SQLITE_LIBDIR)" }
     }
   }
}

将url改为能连上的地址比如url = "git+https://bgithub.xyz/lunarmodules/luasql.git",重新安装这个脚本,就能顺利克隆继续编译了。

复制代码
luarocks install luasql-sqlite3-2.7.0-1.rockspec
Cloning into 'luasql'...
remote: Enumerating objects: 3263, done.
remote: Counting objects: 100% (138/138), done.
remote: Compressing objects: 100% (88/88), done.
remote: Total 3263 (delta 78), reused 53 (delta 50), pack-reused 3125 (from 3)
Receiving objects: 100% (3263/3263), 951.33 KiB | 243.00 KiB/s, done.
Resolving deltas: 100% (1998/1998), done.
Note: switching to 'bbd459e150e3fcc328aac1d794d6fdf62f1ce9e4'.

You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by switching back to a branch.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -c with the switch command. Example:

  git switch -c <new-branch-name>

Or undo this operation with:

  git switch -

Turn off this advice by setting config variable advice.detachedHead to false



luasql-sqlite3 2.7.0-1 depends on lua >= 5.1 (5.4-1 provided by VM: success)
gcc -O2 -fPIC -I/usr/local/include -c src/luasql.c -o src/luasql.o -I/usr/include
gcc -O2 -fPIC -I/usr/local/include -c src/ls_sqlite3.c -o src/ls_sqlite3.o -I/usr/include
gcc  -shared -o /tmp/luarocks_build-LuaSQL-SQLite3-2.7.0-1-9198867/luasql/sqlite3.so src/luasql.o src/ls_sqlite3.o -L/usr/lib/x86_64-linux-gnu -Wl,-rpath,/usr/lib/x86_64-linux-gnu -lsqlite3
luasql-sqlite3 2.7.0-1 is now installed in /usr/local (license: MIT/X11)

使用

luasql-sqlite3没有专门的示例,在http://lunarmodules.github.io/luasql/examples.html找到一个postgreSQL示例,将相关的数据库字符串改为SQLite3就能执行了。

lua 复制代码
-- load driver
local driver = require "luasql.postgres"  --修改为local driver = require "luasql.sqlite3" 
-- create environment object
env = assert (driver.postgres()) --修改为env = assert (driver.sqlite3())
-- connect to data source
con = assert (env:connect("luasql-test"))
-- reset our table
res = con:execute"DROP TABLE people"
res = assert (con:execute[[
  CREATE TABLE people(
    name  varchar(50),
    email varchar(50)
  )
]])
-- add a few elements
list = {
  { name="Jose das Couves", email="jose@couves.com", },
  { name="Manoel Joaquim", email="manoel.joaquim@cafundo.com", },
  { name="Maria das Dores", email="maria@dores.com", },
}
for i, p in pairs (list) do
  res = assert (con:execute(string.format([[
    INSERT INTO people
    VALUES ('%s', '%s')]], p.name, p.email)
  ))
end
-- retrieve a cursor
cur = assert (con:execute"SELECT name, email from people")
-- print all rows, the rows will be indexed by field names
row = cur:fetch ({}, "a")
while row do
  print(string.format("Name: %s, E-mail: %s", row.name, row.email))
  -- reusing the table of results
  row = cur:fetch (row, "a")
end
-- close everything
cur:close() -- already closed because all the result set was consumed
con:close()
env:close()

执行,成功地写入并读取出了数据。

复制代码
lua sqli2.lua
Name: Jose das Couves, E-mail: jose@couves.com
Name: Manoel Joaquim, E-mail: manoel.joaquim@cafundo.com
Name: Maria das Dores, E-mail: maria@dores.com
相关推荐
小江的记录本15 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`15 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存
二宝哥15 小时前
离线安装maven
java·数据库·maven
SZLSDH15 小时前
场景适配论 | 数字孪生IOC建设中渲染技术与智能体能力的协同逻辑
前端·数据库·ai·数字孪生·数据可视化·智能体
这个DBA有点耶15 小时前
SQL改写实战:子查询、CTE、窗口函数性能对比
数据库·mysql·性能优化
@我漫长的孤独流浪16 小时前
数据库完整性约束全解析:从理论到实践
数据库
l1t16 小时前
DeepSeek总结的 DuckDB 1.5.3:并非普通的补丁版本
数据库·duckdb
云商直通车16 小时前
华为云ECS购买与配置超详细教程
服务器·数据库·华为云
hj104316 小时前
fastadmin对接人大金仓 kingbase问题记录&解决
数据库
罗超驿16 小时前
19.告别复杂SQL!用MySQL视图把逻辑拆成“变量”式操作
数据库·mysql·面试