SQLite 和 Lua:从给定行选择列数据

如何从 SQLite 中获取一列的值? 例如,我有一个名为 houseNames 的列,并且想要从第三行获取值,我该怎么做?

点赞
用户9608077
用户9608077

很难说您在编辑后的主要目的是什么,但似乎您正在尝试搜索 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 文档,并检查每个函数的返回代码。

2016-04-04 22:26:40
用户3735873
用户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