[原创]QT:数据库总结(二)之SQL模型类-QSqlQueryModel模型

[原创]QT:数据库总结(二)之SQL模型类-QSqlQueryModel模型

如有改动以CSDN版为主,格式比较好看
http://blog.csdn.net/reborntercel/article/details/7000220


    QSqlQueryModel类为SQL的结果集提供了一个只读的数据模型,下面我们先利用这个类进行一个最简单的操作.

常用函数

void QSqlQueryModel::setQuery ("SQL语句") // 执行SQL语句,此处还可以传入QSqlQuery对象,此时可以利用QSqlQuery类的某些特性,如预操作等.

setHeaderData()     //设置水平头标题

columnCount(); //获得列数

columnCount(); //获得列数

QSqlRecord QSqlQueryModel::record ( int row ) const //返回row行包含的信息,可访问单条的记录

QModelIndex QAbstractItemModel::index ( int row, int column, const QModelIndex & parent = QModelIndex() )  //返回指定的行和列的索引(index)

index.data()  //返回index索引的值

query() //返回与QSqlQuery相关的模型

view plain copy to clipboard print ?
  1. QSqlQueryModel *model = new QSqlQueryModel;  
  2. model->setQuery(“select * from student”);  
  3. model->setHeaderData(0, Qt::Horizontal, tr(“id”));  
  4. model->setHeaderData(1, Qt::Horizontal, tr(“name”));  
  5. QTableView *view = new QTableView;  
  6. view->setModel(model);  
  7. view->show();  
QSqlQueryModel *model = new QSqlQueryModel; model->setQuery(“select * from student”); model->setHeaderData(0, Qt::Horizontal, tr(“id”)); model->setHeaderData(1, Qt::Horizontal, tr(“name”)); QTableView *view = new QTableView; view->setModel(model); view->show();

 

利用query执行SQL语句

view plain copy to clipboard print ?
  1. QSqlQuery query = model->query();  
  2. query.exec("select name from student where id = 1");  
  3. query.next();  
  4. qDebug() << query.value(0).toString(); // 如果上面的select改成insert语句,而且是显示在QTableView中的话,需再查询一次model->setQuery("select ...")才能显示刚插入的语句  
QSqlQuery query = model->query(); query.exec("select name from student where id = 1"); query.next(); qDebug() << query.value(0).toString(); // 如果上面的select改成insert语句,而且是显示在QTableView中的话,需再查询一次model->setQuery("select ...")才能显示刚插入的语句


       因为QSqlQueryMode模型默认是只读的,所以我们在窗口上并不能对表格中的内容进行修改。但是我们可以创建自己的模型,然后按照我们自己的需要来显示数据和修改数据。如果要想使其可读写,需要自己的类继承自QSqlQueryModel,并且重写setData() 和 flags() 两个函数如果我们要改变数据的显示,就要重写data() 函数

view plain copy to clipboard print ?
  1. Qt::ItemFlags MySqlQueryModel::flags(const QModelIndex &index) const //返回表格是否可更改的标志   
  2. {  
  3.      Qt::ItemFlags flags = QSqlQueryModel::flags(index);  
  4.      if (index.column() == 1) //第二个字段可更改,即学生的名字字段   
  5.         flags |= Qt::ItemIsEditable;  
  6.      return flags;  
  7.  }  
  8.   
  9. bool MySqlQueryModel::setData(const QModelIndex &index, const QVariant &value, int /* role *///表格添加数据   
  10. {  
  11.     QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);  
  12.     int id = data(primaryKeyIndex).toInt(); //获取id号 也可以这样用,primaryKeyIndex.data();   
  13.   
  14.     clear();  
  15.     bool isOk;  
  16.     if (index.column() == 1) //第二个属性可更改   
  17.     {  
  18.         QSqlQuery query;  
  19.         query.prepare("UPDATE STUDENT SET NAME = :name WHERE id = :id");  
  20.         query.bindValue(":name","小五");  
  21.         query.bindValue(":id",id);  
  22.         isOk = query.exec();  
  23.   
  24.         refresh();// 此处最好添加代码刷新结果,或在此调用刷新函数   
  25.         return isOK;  
  26.     }  
  27.     return false;  
  28. }  
  29.   
  30. void MySqlQueryModel::refresh() //更新显示   
  31. {  
  32.     setQuery("select * from student");  
  33.     setHeaderData(0, Qt::Horizontal, QObject::tr("学号ID"));  
  34.     setHeaderData(1, Qt::Horizontal, QObject::tr("名字"));  
  35. }  
  36.   
  37. // tata()改写某一个列的显示方式   
  38. QVariant MySqlQueryModel::data(const QModelIndex &index, int role) const  
  39.          //更改数据显示样式   
  40. {  
  41.     QVariant value = QSqlQueryModel::data(index, role);  
  42.     if (role == Qt::TextColorRole && index.column() == 0)  
  43.         return qVariantFromValue(QColor(Qt::red)); //第一个属性的字体颜色为红色   
  44.     return value;  
  45. }  

你可能感兴趣的:([原创]QT:数据库总结(二)之SQL模型类-QSqlQueryModel模型)