QSqlTableModel,使用简单教程。

哎哎9年前 (2015-05-12)C++4361

Qt  QSqlTableModel  使用心得

连接数据库

执行sql查询,条件显示,排序

获取记录数,列数以及记录内容,字段内容

新增,修改,删除,恢复

其它

 

 

1---------------连接数据库(我用的access2003做实验)

在.pro文件添加

QT  +=SQL

win32:CONFIG+=console

 

------------------------MAIN.CPP---------------

#include <QtGui/QApplication>

#include <QSqlDatabase>

#include <QSqlQuery>

#include <QDebug>

#include <QVariant>

#include <QString>

#include <QSqlTableModel>

#include <QTableView>

#include "mainwindow.h"

int main(intargc, char *argv[])

{

    QApplication a(argc, argv);

   // MainWindow w;

    //w.show();

    QSqlDatabase db = QSqlDatabase::addDatabase("QODBC");

    db.setDatabaseName("DRIVER={Microsoft AccessDriver (*.mdb)};FIL={MS Access};DBQ=barcode.mdb;UID='';PWD=''");

    bool ok = db.open();

    if(ok)

    {

        qDebug()<<"connect ok!";

    }

    else

    {

        qDebug()<<"connect error!";

        return false;

    }

    return a.exec();

}

2-----执行sql查询,条件显示,排序

查询:

model = newQSqlTableModel(this);
model->setTable(“student”);
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
model->select(); //选取整个表的所有行
// model->removeColumn(1); //不显示第二列,如果这时添加记录,则该属性的值添加不上

QTableView *view= new QTableView;

        view->setModel(model);

        view->show();

//View->setEditTriggers(QAbstractItemView::NoEditTriggers);  使其不可编辑

条件:(等价于SQL语句的where)

model->setFilter(QObject::tr(“name= ‘admin’”).arg(name)); //根据姓名进行筛选
    model->select(); //显示结果

排序:(等价于ORDERBY)
   model->setSort(0,Qt::AscendingOrder); //id属性,即第0列,升序排列
   model->select();


    model->setSort(0,Qt::DescendingOrder); //id属性,即第0列,降序排
    model->select();

3------获取记录数,列数以及记录内容,字段内容

记录数: Model->rowcount

记录值:

值=model.record(num).value(1).toString(); 

Qrecord record= QSqlRecord record = tablemodel.record(记录行数); 

值=Record.value(“字段名或索引”)

字段数:

字段值:

 

4------新增,修改,删除,提交,撤销

新增:

    int rowNum = model->rowCount();//获得表的行数
   int id = 10;
    model->insertRow(rowNum); //添加一行
    model->setData(model->index(rowNum,0),id);
    //model->submitAll(); //可以直接提交

或者用record添加

QSqlRecord record = tablemodel.record();

record.setValue("nam","new");

model.insertRecord(1,record);

 

修改:

首先用条件找到某一条记录

QSqlRecord record = tablemodel.record(num);

record.setValue("name",record.value("name").toString()+"2");

tablemodel.setRecord(num,record);

if(tablemodel.submitAll())

"成功!"

else

"失败!"

或者用下面方法用setData()来修改,代码如下: 
model.setData(model.index(1,1),"new");
 
if(tablemodel.submitAll()) 
   "成功!"
else 
   "失败!"


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

如果没有table

tablemodel.removeRows(起始行, 要删除的总行数); 
model.submitAll(); 


提交  

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

撤销  

  model->revertAll();

5------其它

 




he QSqlTableModel class provides an editable data model for a single database table. More...

  1. <span class="preprocessor" style="color:rgb(64,64,64)">#include <QSqlTableModel></span>  

Inherits: QSqlQueryModel.

Inherited by: QSqlRelationalTableModel.

Public Types

enumEditStrategy { OnFieldChange, OnRowChange, OnManualSubmit }

Public Functions


QSqlTableModel ( QObject * parent = 0, QSqlDatabase db = QSqlDatabase() )
virtual~QSqlTableModel ()
QSqlDatabasedatabase () const
EditStrategyeditStrategy () const
intfieldIndex ( const QString & fieldName ) const
QStringfilter () const
boolinsertRecord ( int row, const QSqlRecord & record )
boolisDirty ( const QModelIndex & index ) const
QSqlIndexprimaryKey () const
virtual voidrevertRow ( int row )
virtual boolselect ()
virtual voidsetEditStrategy ( EditStrategy strategy )
virtual voidsetFilter ( const QString & filter )
boolsetRecord ( int row, const QSqlRecord & record )
virtual voidsetSort ( int column, Qt::SortOrder order )
virtual voidsetTable ( const QString & tableName )
QStringtableName () const

Reimplemented Public Functions

virtual voidclear ()
virtual QVariantdata ( const QModelIndex & index, int role = Qt::DisplayRole ) const
virtual Qt::ItemFlagsflags ( const QModelIndex & index ) const
virtual QVariantheaderData ( int section, Qt::Orientation orientation, int role = Qt::DisplayRole ) const
virtual boolinsertRows ( int row, int count, const QModelIndex & parent = QModelIndex() )
virtual boolremoveColumns ( int column, int count, const QModelIndex & parent = QModelIndex() )
virtual boolremoveRows ( int row, int count, const QModelIndex & parent = QModelIndex() )
virtual introwCount ( const QModelIndex & parent = QModelIndex() ) const
virtual boolsetData ( const QModelIndex & index, const QVariant & value, int role = Qt::EditRole )
virtual voidsort ( int column, Qt::SortOrder order )

Public Slots

virtual voidrevert ()
voidrevertAll ()
virtual boolsubmit ()
boolsubmitAll ()

Signals

voidbeforeDelete ( int row )
voidbeforeInsert ( QSqlRecord & record )
voidbeforeUpdate ( int row, QSqlRecord & record )
voidprimeInsert ( int row, QSqlRecord & record )

Protected Functions

virtual booldeleteRowFromTable ( int row )
QModelIndexindexInQuery ( const QModelIndex & item ) const
virtual boolinsertRowIntoTable ( const QSqlRecord & values )
virtual QStringorderByClause () const
virtual QStringselectStatement () const
voidsetPrimaryKey ( const QSqlIndex & key )
voidsetQuery ( const QSqlQuery & query )
virtual boolupdateRowInTable ( int row, const QSqlRecord & values )