开发背景是这样的:当后台开始进行数据库更新,用户会看到一个等待界面。数据库更新完成后,等待界面自动消失。
操作数据库
QT提供多种数据存储方式,我们可以选择一种driver,然后用标准查询语句进行系列操作。
下面是非常简单的例子:
#include <QtSql/QSqlDatabase>
#include <QCoreApplication>
#include <QStringList>
#include <QDebug>
#include <QSqlError>
#include <QSqlQuery>
int main(int argc, char **argv){
QCoreApplication app(argc, argv);
QStringList drivers = QSqlDatabase::drivers();
foreach (QString it, drivers) {
qDebug()<<it;
}
qDebug()<<"";
QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");
db.setDatabaseName("./student");
if(db.open()){
QSqlQuery query;
if(!query.exec("create table today(title text)")){
qDebug()<<"create: "<<query.lastError();
}
if(!query.exec("insert into today values('hello world')")){
qDebug()<<"insert: "<&l