sqlite3 - sqlite3数据库操作#

示例

-- 注意, 本库仍处于开发阶段, 大部分BSP尚不支持本库
-- 本移植基于 sqlite3 3.44.0
sys.taskInit(function()
    sys.wait(1000)
    local db = sqlite3.open("/ram/test.db")
    log.info("sqlite3", db)
    if db then
        sqlite3.exec(db, "CREATE TABLE devs(ID INT PRIMARY KEY NOT NULL, name CHAR(50));")
        sqlite3.exec(db, "insert into devs values(1, \"ABC\");")
        sqlite3.exec(db, "insert into devs values(2, \"DEF\");")
        sqlite3.exec(db, "insert into devs values(3, \"HIJ\");")
        local ret, data = sqlite3.exec(db, "select * from devs;")
        log.info("查询结果", ret, data)
        if ret then
            for k, v in pairs(data) do
                log.info("数据", json.encode(v))
            end
        end
        sqlite3.close(db)
    end
end)

sqlite3.open(path)#

打开数据库

参数

传入值类型

解释

string

数据库文件路径,必须填写,不存在就会自动新建

返回值

返回值类型

解释

userdata

数据库指针,是否就返回nil

例子

local db = sqlite3.open("/test.db")
if db then
   -- 数据库操作xxxx

    -- 用完必须关掉
    sqlite3.close(db)
end

sqlite3.exec(db, sql)#

执行SQL语句

参数

传入值类型

解释

userdata

通过sqlite3.open获取到的数据库指针

string

SQL字符串,必须填写

返回值

返回值类型

解释

boolean

成功返回true,否则返回nil

table

成功返回查询结果(若有),否则返回报错的字符串

例子


sqlite3.close(db)#

关闭数据库

参数

传入值类型

解释

userdata

通过sqlite3.open获取到的数据库指针

返回值

返回值类型

解释

boolean

成功返回true,否则返回nil

例子