SQLite 和 Lua:从给定行选择列数据
2016-4-4 21:50:15
收藏:0
阅读:64
评论:2
如何从 SQLite 中获取一列的值?
例如,我有一个名为 houseNames 的列,并且想要从第三行获取值,我该怎么做?
点赞
用户3735873
另一种方法是使用SQLit直接提取给定的行。显然,您需要某种确定第三行的方法,例如通过rowid,某个其他字段,按字母顺序排序的houseName等等。
注意:数据库中的行没有任何固有顺序(至少在理论上),即使是添加行的顺序,即使看起来是这样的,除非给出ORDER BY子句,否则选择的行也没有保证会按预期顺序返回。
一旦您拥有了这个,就可以使用LIMIT子句两次来获取所需的行。您需要一个带有子查询的查询。
在子查询中,将结果限制为您要查找的行号(例如,第3行)。在外部查询中,按相反的方式排序并限制为1。
示例:
--假设lsqlite3已经作为sqlite3加载
db = sqlite3.open(':memory:')
sql = [[
create table t(houseNames text);
insert into t values('a'),('b'),('c'),('d'),('e'),('f');
]]
db: exec(sql)
sql = [[
select houseNames from (select houseNames from t order by houseNames limit 3)
order by houseNames desc
limit 1;
]]
for house_name in db:urows(sql) do
print(house_name)
end
db: close()
您还可以使用带有OFFSET子句的LIMIT并避免子查询:
sql = [[
select houseNames from t order by houseNames limit 1 offset 2
]]
2016-04-04 23:12:39
评论区的留言会收到邮件通知哦~
推荐文章
- 如何将两个不同的lua文件合成一个 东西有点长 大佬请耐心看完 我是小白研究几天了都没搞定
- 如何在roblox studio中1:1导入真实世界的地形?
- 求解,lua_resume的第二次调用继续执行协程问题。
- 【上海普陀区】内向猫网络招募【Skynet游戏框架Lua后端程序员】
- SF爱好求教:如何用lua实现游戏内调用数据库函数实现账号密码注册?
- Lua实现网站后台开发
- LUA错误显式返回,社区常见的规约是怎么样的
- lua5.3下载库失败
- 请问如何实现文本框内容和某个网页搜索框内容连接,并把网页输出来的结果反馈到另外一个文本框上
- lua lanes多线程使用
- 一个kv数据库
- openresty 有没有比较轻量的 docker 镜像
- 想问一下,有大佬用过luacurl吗
- 在Lua执行过程中使用Load函数出现问题
- 为什么 neovim 里没有显示一些特殊字符?
- Lua比较两个表的值(不考虑键的顺序)
- 有个lua简单的项目,外包,有意者加微信 liuheng600456详谈,最好在成都
- 如何在 Visual Studio 2022 中运行 Lua 代码?
- addEventListener 返回 nil Lua
- Lua中获取用户配置主目录的跨平台方法
很难说您在编辑后的主要目的是什么,但似乎您正在尝试搜索 Lua 的 sqlite3 包装器。从我的经验来看,lsqlite3 将适合您的需求。
至于您的问题,这个库的主要用途是使用迭代器:
local sqlite3 = require("lsqlite3") local db = sqlite3.open_memory() for row in db:nrows("SELECT * FROM test") do print(row.id, row.content) end所以您可以获得任何您想要的详细信息,甚至可以通过列名而不是列号来更方便地进行操作。
要从数据库中获取第 n 行数据,您可以这样做:
local sqlite3 = require("lsqlite3") local db = sqlite3.open_memory() local stmt = db:prepare("SELECT * FROM Players") local maxRowNumber = 6 for rowNumber=1, maxRowNumber do stmt:step() row = stmt:get_named_values() end不要直接使用此代码,我只是提供了一个简单的示例。您应该先阅读 lsqlite3 的 API 文档,并检查每个函数的返回代码。