关于QSqlTableModel的使用说明(QT上创建本地SQL)

本文介绍如何使用Qt中的QSqlTableModel类简化数据库操作。包括创建数据库、数据表及记录,展示并修改QTableView中的数据,以及实现增删查改等常见数据库操作。

前言:通常我们操作数据库时,需要使用sql语句;在qt开发环境中提供了QSqlTableModel类,它可以通过简单的接口去操作数据库,即使不熟悉sql语句也可以对数据库进行大部分的操作,而且该模型还具有数据缓存功能,在修改数据后并不是立刻同步到数据库中,允许用户进行数据撤回,如果已经提交到数据库的数据就不能进行撤回了;QSqlTableModel还有一个非常方便的操作就是它可以将数据库的所有记录显示到QTableView控件上,并可以直接通过QTableView控件对数据库任意位置的数据进行修改。下面就QSqlTableModel类的使用进行举例说明。

Qt 5.14完整源码下载,下载链接;源码附带详细注释,十分具有参考意义。

效果图预览:

1.创建本地数据库

   /*设置使用的数据库驱动*/
    QSqlDatabase  sqldb = QSqlDatabase::addDatabase("QSQLITE");
    /*打开指定文件下的数据库文件,如果不存在则创建*/
    sqldb.setDatabaseName("./test.db");
    if(sqldb.open()){
        qDebug() <<"[te
### QSqlTableModel OnManualSubmit 使用方法及注意事项 #### 1. OnManualSubmit 模式的定义 `QSqlTableModel::OnManualSubmit` 是 `QSqlTableModel` 提供的一种编辑策略,表示所有的更改不会立即提交到数据库,而是需要显式调用 `submitAll()` 方法来保存所有未完成的修改[^2]。 #### 2. 使用方法 以下是使用 `OnManualSubmit` 编辑策略的具体方式: - 创建 `QSqlTableModel` 对象时指定该模式: ```cpp model->setEditStrategy(QSqlTableModel::OnManualSubmit); ``` - 执行查询操作以加载数据: ```cpp model->select(); ``` - 修改模型中的数据(例如插入、更新或删除记录),这些更改会暂时存储在内存中而不会影响实际数据库。 - 当准备好将所有更改写入数据库时,调用以下方法: ```cpp if (!model->submitAll()) { qDebug() << "Error:" << model->lastError().text(); } ``` 如果发生错误,则可以通过 `lastError()` 获取详细的错误信息。 - 若要撤销所有尚未提交的更改,可调用 `revertAll()` 方法: ```cpp model->revertAll(); ``` #### 3. 注意事项 - **性能优化**:由于此模式下只有当调用了 `submitAll()` 或者程序结束前才会真正同步至数据库,因此适合批量处理大量数据的情况。相比每次单独提交每条记录的方式更加高效。 - **事务管理**:需要注意的是,在某些情况下可能还需要手动控制 SQLite 的事务机制以确保一致性[^5]。 - **线程安全问题**:虽然 QtSQL 不直接涉及多线程编程复杂度,但如果应用程序运行于多个并发执行路径上,则应特别小心避免竞态条件等问题出现。 - **错误检测与恢复**:始终检查返回值以及潜在异常情况下的行为表现;对于失败的操作尝试提供合理的反馈给最终用户或者采取适当措施进行回滚等动作。 ```cpp // 示例代码展示完整的流程 #include <QSqlTableModel> #include <QDebug> void exampleUsageOfOnManualSubmit(QSqlDatabase &db) { QSqlTableModel *model = new QSqlTableModel(nullptr, db); model->setTable("users"); model->setEditStrategy(QSqlTableModel::OnManualSubmit); if (model->select()) { // 加载表格内容 int row = model->rowCount(); // 插入新行作为演示目的 model->insertRow(row); QModelIndex index = model->index(row, 0); // 假设第一列为ID字段 model->setData(index, QVariant(99)); // 设置新的唯一标识符 bool success = model->submitAll(); // 尝试一次性提交全部变更 if(!success){ qDebug()<<"Failed to submit changes:"<<model->lastError().text(); model->revertAll(); // 如果出现问题则还原状态 } } else{ qDebug()<<"Unable to load data from table."; } delete model; } ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值