Qt使用 QSqlTableModel 模型操作数据库

        Qt可以使用SQL语句完成对数据库的常规操作。如果不需要复杂的查询,QSqlTableModel模型基本可以满足需求。本文将针对QSqlTableModel模型操作sqlite进行说明。
         通常,Qt要进行SQL数据库操作,需要在 .pro 文件中加上这么一句:
    
    
QT += sql
         Qt默认的情况下会加载sqlite驱动,下面一段代码为创建一个数据库连接:
    
    
QSqlDatebase db = QSqlDatabase:addDatabase("QSQLITE");
db . setDatabaseName ( "dbname.db" );
if (!db.open()) {
QMessageBox::critical(0, QObject::tr("Database Error")), db.lastError().text());
}
         关于addDatabase(),可以指定名字(暂不叙述),如不指定,将采用系统默认的 QSqlDatabase::defaultConnection 这一名字。此时,Qt会创建一个默认的连接。此后,我们并不需要指定操作的是哪个数据库,而是使用当前的连接。
         接下来,我们需要为模型设置表:
   
   
QSqlTableModel model;
model.setTable("tablename");
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
如下是Qt帮助文档中对setTable()的说明:
   
   
void QSqlTableModel::setTable(const QString & tableName)
 
Sets the database table on which the model operates to tableName. Does not select data from the table, but fetches its field information.
To populate the model with the table's data, call select().
// 设置要操作的数据库表。并没有从表中选择数据,而是获取它的字段。
// 如要用表中的数据填充模型,需调用 select()
设置表后,我们就可以 应用QSqlTableModel模型 进行数据库的基本操作了,即增、删、改、查。
          一、  
   
   
model . setFilter ( "age > 20 and age < 25" );
if (model.select()) {
for (int i = 0; i < model.rowCount(); ++i) {
QSqlRecord record = model.record(i);
QString name = record.value("name").toString();
int age = record.value("age").toInt();
qDebug() << name << ": " << age;
}
}
        在Qt中,使用QSqlRecord来取出每一条数据,用value()返回相应字段的数据,随后我们可以根据需要转化为我们想要的数据类型。
        下面我们重点说一下setFilter(), 如下是Qt帮助文档中对setFilter()的说明:
    
    
void QSqlTableModel::setFilter(const QString & filter)
 
The filter is a SQL WHERE clause without the keyword WHERE (for example, name='Josephine').
 
If the model is already populated with data from a database, the model re-selects it with the new filter. Otherwise, the filter will be applied the next time select() is called.
 
//filter是一个没有关键字WHERE的SQL语句
//如果当前模型已经从数据库中填充了数据,则立即应用新的过滤条件。否则,过滤条件将在下一次调用select()时生效。
        可知 ,setFilter()一般与select()一起使用。
         如下是Qt帮助文档中对select()的说明:
    
    
//如下是Qt对select的帮助文档
bool QSqlTableModel::select()
 
Populates the model with data from the table that was set via setTable(), using the specified filter and sort condition, and returns true if successful; otherwise returns false.
 
//根据指定的筛选和排序条件,用setTable所设置的表的数据填充模型,如果成功则返回true,否则返回false
        因此, 我们可以这样做:① 在setTable后就调用select(),而不必每次调用select() ; ② 在每次调用setFilter()后调用select().
          二、增
     
     
QSqlRecord record = model->record();
record.setValue("name", "张三");
record.setValue("age", 12);
model->insertRecord(row, record);
model->submitAll();
        通常使用 insertRecord()来增加一行。
      
      
bool QSqlTableModel::insertRecord(int row, const QSqlRecord & record)
 
Inserts the record at position row. If row is negative, the record will be appended to the end. Calls insertRows() and setRecord() internally.
Returns true if the record could be inserted, otherwise false.
Changes are submitted immediately for OnFieldChange and OnRowChange. Failure does not leave a new row in the model.
 
//在参数row的位置插入一行。如果行不存在,则该记录将被附到结尾。
//若编辑策略为 OnManualSubmit或 OnRowChange 时,修改将立即生效。
       
       
bool QSqlTableModel::submitAll()
 
Submits all pending changes and returns true on success. Returns false on error, detailed error information can be obtained with lastError().
 
In OnManualSubmit, on success the model will be repopulated. Any views presenting it will lose their selections.
 
//提交待定的修改,成功则返回true。
//在OnManualSubmit模式下,成功后数据模型将会被重新填充。任何应用这个数据模型进行显示的控件将会失去原来的选择。
        若我们选用 OnManualSubmit模式,则需要使用submitAll();
        三、改
        与insertRecord()类似,使用setRecord()来修改某一条记录,并同时需要注意在需要时调用submitAll()。
     
     
bool QSqlTableModel::setRecord(int row, const QSqlRecord & values)   
        四、删
        删较简单,使用removeRow,或removeRows实现。同样要注意submitAll()的使用。
      
      
bool QAbstractItemModel::removeRow(int row, const QModelIndex & parent = QModelIndex())
       
       
bool QAbstractItemModel::removeRows(int row, int count, const QModelIndex & parent = QModelIndex())
        关于用模型操作数据库的常用方法就是这些了,还有一些方法,用到了再查阅也是可以的。
         Qt Assistant是一个详尽具体的说明文档,凭借着文档,可以不看其他教程也可以使用Qt了。很多次因为网上没有足够的资料而举步不前,而查看他之后,每次都是恍然大悟,收获颇丰。因此,真的要养成遇到问题查阅Qt Assistant的好习惯。

  • 4
    点赞
  • 39
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 【QT数据库实战之qsqltablemodel模型.rar是一份实用的资料,它详细介绍了如何利用QT框架中的QSqlTableModel模型操作数据库,并且提供了完整的代码示例和演示视频,为学习者提供了更加直观、全面的学习体验。 其中,资料着重介绍了QSqlTableModel模型使用方法和常见操作,包括如何建立数据源、如何进行数据查询、修改和删除等。此外,它还提供了丰富的实例程序,通过这些程序,学习者可以深入了解不同的应用场景下如何使用QSqlTableModel模型来完成数据处理的操作。 在实际学习中,这份资料可以作为一个很好的参考教材。它清晰地展示了QT框架的优势和便捷性,帮助学习者快速了解QSqlTableModel模型使用方法和注意事项,提高了学习效率。 总的来说,【QT数据库实战之qsqltablemodel模型.rar是一份很有价值的学习资料,对于想深入学习QT数据库编程的开发者来说,是一份不可多得的资料。 ### 回答2: 【qt数据库实战之qsqltablemodel模型.rar 是一个实战教程,主要讲解 qsqltablemodel 模型Qt 数据库编程中的应用。该教程适合于想要学习 Qt 数据库编程的开发者,熟悉 C++ 语言以及 Qt 编程基础的开发者更容易理解和掌握其中的内容。 该教程主要分为三个部分Qt 数据库连接的建立、qsqltablemodel 模型使用以及 qsqlquerymodel 模型使用。通过阅读该教程,开发者可以学习到如何运用 Qt 自带的数据库模块进行数据库编程,如何使用 qsqltablemodel 模型操作数据库,并且能够理解 qsqlquerymodel 模型的用处和优劣势。 在该教程中,开发者将会联系到一个实际的案例,即利用 qsqltablemodel 模型开发一个图书管理系统。通过对该案例的开发实践,开发者可以更好地理解 qsqltablemodel 模型的实际使用,掌握 qsqltablemodel 模型数据库编程中的应用。 总之,【qt数据库实战之qsqltablemodel模型.rar 是一份非常实用的 Qt 数据库编程教程,可以帮助开发者对 Qt 数据库编程有更深入的了解和掌握。 ### 回答3: qt 数据库实战之 qsqltablemodel 模型.rar 是一个用于学习 qt 数据库编程的资源文件。qsqltablemodelqt 框架中的一个模型类,可以用于对数据库进行增删改查操作,并在 qt 的相关控件中显示查询结果。 该资源文件包含了一个完整的 qt 项目,其中包含了对 qsqltablemodel 类的使用示例,可以通过该示例快速入门 qt 数据库编程,掌握 qsqltablemodel 类的使用方法。该示例包含了对 sqlite 数据库的连接和操作,可以让你了解 sqlite 数据库的基本用法。 此外,该资源文件还包含了一个使用 qsqltablemodel 类和 qt 控件实现的简单的学生管理系统,可以让你更深入地了解 qsqltablemodel 类的使用qt 数据库编程的实战应用。通过学习和实践,你可以在实际应用中运用到这些知识,提高自己的编程水平和实践能力。 总之,qt 数据库实战之 qsqltablemodel 模型.rar 是一份非常有价值的 qt 数据库编程资源,适合想要学习和掌握 qt 数据库编程的开发人员使用

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值