0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

英创信息技术Linux主板Qt数据库应用程序简介

英创信息技术 来源:英创信息技术 作者:英创信息技术 2020-01-17 09:44 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

SQLite是一个开源的嵌入式数据库,其特点是零配置,可移植性好,小巧、高效而且可靠。同时SQLite的数据库权限只依赖于文件系统,没有用户帐户的概念,因此使用起来很方便。英创Linux主板能够很好的支持SQLite,相关的测试例程已经在光盘中提供,本文主要简介Qt中的数据库开发。

Qt中的QtSql模块提供了对数据库的支持,该模块中的众多类基本上可以分为三层:用户接口层、SQL接口层,驱动层。

其中驱动层为具体的数据库和SQL接口层之间提供了底层的桥梁;SQL接口层提供了对数据库的访问;用户接口层的几个类实现了将数据库中的数据链接到窗口部件上,这些类是使用前一章的模型/视图框架实现的,它们是更高层次的抽象,即便不熟悉SQL也可以操作数据库。如果要使用QtQql模块中的这些类,需要在项目文件(.pro文件)中添加QT += sql这一行代码。

QtSql模块使用数据库驱动来和不同的数据库接口进行通信。由于Qt的SQL模型的接口是独立于数据库的,所以所有数据库特定的代码都包含在了这些驱动中。我们使用的免费的Qt只提供了SQLite和ODBC数据库的驱动。创建数据库连接:

QSqlDatabase db = QSqlDatabase::addDatabase('QSQLITE'); //指定驱动
db.setDatabaseName('/mnt/nandflash/my.db'); //指定路径

使用open()函数将数据库打开,如果打开失败,则弹出对话提示框:
if (!db.open())
{
QMessageBox::critical(0, qApp->tr('Cannot open database'),
qApp->tr('Unable to establisha database connection.'
), QMessageBox::Cancel);
return false;
}

使用QSqlQuery创建了一个product表,并插入id,name和speed三个字段的三条记录。其中,id字段是int类型的,''primary key ''表明该字段是主键,它不能为空,而且不能有重复的值;而name字段是varchar类型的,Speed字段也是varchar类型的,注意这里使用的SQL语句都要包含在双引号中,如果一行写不完,那么分行后,每一行都要使用两个双引号引起来:

QSqlQuery query;
// 创建product表
query.exec(QString ('create table product (id int primary key, '
'name varchar, Speed varchar)'));
query.exec(QString ('insert into product values(1, 'EM335x', '1GHZ')'));
query.exec(QString ('insert into product values(2, 'EM3352', '600MHZ')'));
query.exec(QString ('insert intoproduct values(3, 'EM9280', '454MHZ')'));

SQL表格模型提供了一个一次只能操作一个SQL表的读/写模型QSqlTableModel,它可以浏览和修改独立的SQL表,并且只需编写很少的代码,而且不需要了解SQL语法。该模型默认是可读可写的。我们首先创建一个QSqlTableModel,只须使用setTable()来为其指定数据库表,然后使用select()函数进行查询:

model = new QSqlTableModel(this);
model->setTable('product');
model->select();
// 设置编辑策略
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
ui->tableView->setModel(model);

在使用该模型前,一般还要设置其编辑策略,它由QsqlTableModel::EditStrategy枚举变量定义,一共有三个值:
QsqlTableModel::OnFieldChange:所有对模型的改变都会立即应用到数据库。
QsqlTableModel::OnRowChange:对一条记录的改变会在用户选择另一条记录时被应用。
QsqlTableModel::OnManualSubmit:所有的改变都会在模型中进行缓存,知道调用submitAll()或者revertAll()函数。

下面添加一些功能按钮,逐个实现他们:

// 提交修改按钮
void MainWindow::on_pushButton_clicked()
{
// 开始事务操作
model->database().transaction();
if (model->submitAll()) {
model->database().commit(); //提交
} else {
model->database().rollback(); //回滚
QMessageBox::warning(this, tr('tableModel'),
tr('数据库错误: %1').arg(model->lastError().text()));
}
}

如果可以使用submitAll()将模型中的修改向数据库提交成功,那么执行commit(),否则进行回滚rollback(),并提示错误信息,下面是撤销修改按钮:

// 撤销修改按钮
void MainWindow::on_pushButton_2_clicked()
{
model->revertAll();
}

这里使用了setFilter()函数来进行数据筛选,采用id来筛选:

// 查询按钮,进行筛选
void MainWindow::on_pushButton_7_clicked()
{
QString id = ui->comboBox->currentText();
//根据id进行筛选,一定要使用单引号
model->setFilter(QString('id = '%1'').arg(id));
model->select();
}

使用setTable()来指定数据库表,然后使用select()函数进行查询:
// 显示全表按钮
void MainWindow::on_pushButton_8_clicked()
{
model->setTable('product');
model->select();
}

// 按id升序排列按钮
void MainWindow::on_pushButton_5_clicked()
{
//id属性,即第0列,升序排列
model->setSort(0, Qt::AscendingOrder);
model->select();
}

// 按id降序排列按钮
void MainWindow::on_pushButton_6_clicked()
{
model->setSort(0, Qt::DescendingOrder);
model->select();
}

// 删除选中行按钮
void MainWindow::on_pushButton_4_clicked()
{
// 获取选中的行
int curRow = ui->tableView->currentIndex().row();
// 删除该行
model->removeRow(curRow);
int ok = QMessageBox::warning(this,tr('删除当前行!'),
tr('你确定删除当前行吗?'), QMessageBox::No,QMessageBox::Yes);
if(ok == QMessageBox::No)
{ // 如果不删除,则撤销
model->revertAll();
} else { // 否则提交,在数据库中删除该行
model->submitAll();
}
}

// 添加记录按钮
void MainWindow::on_pushButton_3_clicked()
{
// 获得表的行数
int rowNum = model->rowCount();
int id = rowNum + 1 ;
// 添加一行
model->insertRow(rowNum);
model->setData(model->index(rowNum,0), id);
// 可以直接提交
//model->submitAll();
}

运行效果:

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • Linux
    +关注

    关注

    88

    文章

    11893

    浏览量

    220211
  • 嵌入式主板
    +关注

    关注

    7

    文章

    6107

    浏览量

    37269
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    泊沧数据码科技达成商业合作,以国产数据底座加速AI硬件自主创新

    泊沧数据与国内AI计算头部企业——广州信息科技有限公司(简称:码科技),正式签署商业合同。码科技通过国
    的头像 发表于 05-09 17:33 1507次阅读
    泊沧<b class='flag-5'>数据</b>与<b class='flag-5'>英</b>码科技达成商业合作,以国产<b class='flag-5'>数据</b>底座加速AI硬件自主创新

    瀚高数据库深度参编国家标准《信息技术 云原生关系数据库管理系统技术要求》正式发布

    济南2026年4月15日 /美通社/ -- 近日,国家市场监督管理总局、国家标准化管理委员会正式发布国家标准 GB/T 47343-2026《信息技术 云原生关系数据库管理系统技术要求》。作为我国
    的头像 发表于 04-15 16:41 453次阅读

    生产环境数据库连接池耗尽的全流程排查与性能优化实战

    数据库连接池是应用程序数据库之间的缓存连接组件。连接池在应用程序启动时创建一组数据库连接,应用程序
    的头像 发表于 03-27 15:58 550次阅读

    龙芯主板——信体系的智慧硬核基石

    信息技术飞速发展的当下,信体系的自主可控与创新升级已成为国家战略层面的关键任务。作为信产业发展的重要基础硬件支撑,国产工控主板的自主可控程度直接决定信创新基建的稳固性,正发挥着日
    的头像 发表于 03-11 10:44 325次阅读
    龙芯<b class='flag-5'>主板</b>——信<b class='flag-5'>创</b>体系的智慧硬核基石

    恒讯科技解析:如何安装MySQL并创建数据库

    安装和管理MySQL不必复杂。只需几分钟,你就能在Linux服务器上搭建MySQL,创建第一个数据库,甚至自动化备份——同时确保数据安全有序。 什么是 MySQL  MySQL 是一个关系型
    的头像 发表于 01-14 14:25 530次阅读

    国产数据库的AI战事

    国产数据库硝烟再起,Vastbase V100构筑企业智能基座
    的头像 发表于 10-24 20:45 4607次阅读
    国产<b class='flag-5'>数据库</b>的AI战事

    mysql数据恢复—mysql数据库表被truncate的数据恢复案例

    某云ECS网站服务器,linux操作系统,部署了mysql数据库。工作人员在执行数据库版本更新测试时,错误地将本应在测试执行的sql脚本在生产
    的头像 发表于 09-11 09:28 1438次阅读
    mysql<b class='flag-5'>数据</b>恢复—mysql<b class='flag-5'>数据库</b>表被truncate的<b class='flag-5'>数据</b>恢复案例

    数据库性能优化指南

    作为一名在大厂摸爬滚打多年的运维老兵,我见过太多因为数据库性能问题导致的生产事故。今天分享一套完整的数据库优化方法论,从SQL层面到硬件配置,帮你彻底解决性能瓶颈!
    的头像 发表于 08-18 11:21 1005次阅读

    智慧新核心,龙芯主板助力信体系再升级

    信息技术飞速发展的当下,信体系的自主可控与创新升级已成为国家战略层面的关键任务。作为信产业发展的重要基础硬件支撑,国产工控主板正发挥着日益重要的作用。
    的头像 发表于 08-11 09:14 877次阅读

    数据库数据恢复—服务器异常断电导致Oracle数据库故障的数据恢复案例

    Oracle数据库故障: 某公司一台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持一致性”。该Oracle数据库
    的头像 发表于 07-24 11:12 989次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—服务器异常断电导致Oracle<b class='flag-5'>数据库</b>故障的<b class='flag-5'>数据</b>恢复案例

    飞腾主板为信产业发展提高硬实力

    信息技术飞速发展的当下,信产业已成为我国实现科技自立自强、保障国家信息安全的关键领域。信,即信息技术应用创新,其核心目标是实现
    的头像 发表于 07-22 18:20 902次阅读

    三款主流国产数据库技术特点

    随着数字经济的快速发展和数据安全要求的提升,国产数据库正迎来前所未有的发展机遇。在信浪潮推动下,达梦数据库、TiDB、华为高斯数据库等国产
    的头像 发表于 07-14 11:08 1455次阅读

    数据库数据恢复—MongoDB数据库文件丢失的数据恢复案例

    MongoDB数据库数据恢复环境: 一台操作系统为Windows Server的虚拟机上部署MongoDB数据库。 MongoDB数据库故障: 工作人员在MongoDB服务仍
    的头像 发表于 07-01 11:13 914次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—MongoDB<b class='flag-5'>数据库</b>文件丢失的<b class='flag-5'>数据</b>恢复案例

    数据库数据恢复—SQL Server数据库被加密如何恢复数据

    SQL Server数据库故障: SQL Server数据库被加密,无法使用。 数据库MDF、LDF、log日志文件名字被篡改。
    的头像 发表于 06-25 13:54 953次阅读
    <b class='flag-5'>数据库</b><b class='flag-5'>数据</b>恢复—SQL Server<b class='flag-5'>数据库</b>被加密如何恢复<b class='flag-5'>数据</b>?

    科普|信是什么?一文读懂“信息技术应用创新”战略

    什么是信?信,即“信息技术应用创新”,是国家推动IT系统自主可控、安全可控的重要战略工程。它不仅是技术层面的创新,更承载着保障国家网络安全、推动产业升级和实现数字主权的重任。简单来
    的头像 发表于 06-13 10:06 1w次阅读
    科普|信<b class='flag-5'>创</b>是什么?一文读懂“<b class='flag-5'>信息技术</b>应用创新”战略