如何在QML使用Sqlite数据库

如何在QML使用Sqlite数据库,第1张

在程序中,我们经常需要把一些数据持久化,比如一些设置信息和程序配置。QML并不能直接访问本地文件,但是可以通过

Offline Storage API访问本地Sqlite数据库,从而达到目的。

首先在qml目录下创建一个storage.js

Js代码 收藏代码

//storage.js

// 首先创建一个helper方法连接数据库

function getDatabase() {

return openDatabaseSync("MyAppName", "1.0", "StorageDatabase", 100000)

}

// 程序打开时,初始化表

function initialize() {

var db = getDatabase()

db.transaction(

function(tx) {

// 如果setting表不存在,则创建一个

// 如果表存在,则跳过此步

tx.executeSql('CREATE TABLE IF NOT EXISTS settings(setting TEXT UNIQUE, value TEXT)')

})

}

// 插入数据

function setSetting(setting, value) {

var db = getDatabase()

var res = ""

db.transaction(function(tx) {

var rs = tx.executeSql('INSERT OR REPLACE INTO settings VALUES (?,?)', [setting,value])

//console.log(rs.rowsAffected)

if (rs.rowsAffected >0) {

res = "OK"

} else {

res = "Error"

}

}

)

return res

}

// 获取数据

function getSetting(setting) {

var db = getDatabase()

var res=""

db.transaction(function(tx) {

var rs = tx.executeSql('SELECT value FROM settings WHERE setting=?', [setting])

if (rs.rows.length >0) {

res = rs.rows.item(0).value

} else {

res = "Unknown"

}

})

return res

}

然后就可以在qml里调用了

Qml代码 收藏代码

import Qt 4.7

//引入storage.js,起个别名Storage,以供后面使用

import "storage.js" as Storage

Rectangle {

width: 360

height: 360

id: screen

Text {

id: textDisplay

anchors.centerIn: parent

}

Component.onCompleted: {

// 初始化数据库

Storage.initialize()

// 赋值

Storage.setSetting("mySetting","myValue")

//获取一个值,并把它写在textDisplay里

textDisplay.text = "The value of mySetting is:\n" + Storage.getSetting("mySetting")

}

}

Qt 中的数据库 *** 作,由于内嵌了一个 sqlite 数据库驱动,在普通应用中可以较为轻松地应付一些需求。

Qt Quick Local Storage

QML 提供了一个 QtQuick.LocalStorage 模块,用以 *** 作 sqlite 数据库。不支持异步。

这个模块实现了 w3c 的 Web Database 标准。

所以可以参考HTML5本地存储——Web SQL Database。

由于Web SQL Database规范已经被废弃,原因说的很清楚,当前的 SQL 规范采用 SQLite 的 SQL 方言,而作为一个标准,这是不可接受的,每个浏览器都有自己的实现这还搞毛的标准。

当然,在 QML 的世界里大可不必担心这个。Qt 使用统一的实现标准,表现出来的平台无关性。

看你的mysql当前默认的存储引擎:

mysql>show variables like '%storage_engine%'

你要看某个表用了什么引擎(在显示结果里参数engine后面的就表示该表当前用的存储引擎):

mysql>show create table 表名


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/sjk/9906768.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存