LOFTER for ipad —— 让兴趣,更有趣

点击下载 关闭
QT笔记:数据库总结(二)之SQL模型类-QSqlQueryMo
2017-02-13

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相关的模型


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语句


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() 函数。


Qt::ItemFlags MySqlQueryModel::flags(const QModelIndex &index) const //返回表格是否可更改的标志

{

Qt::ItemFlags flags = QSqlQueryModel::flags(index);

if (index.column() == 1) //第二个字段可更改,即学生的名字字段

flags |= Qt::ItemIsEditable;

return flags;

}

bool MySqlQueryModel::setData(const QModelIndex &index, const QVariant &value, int /* role */) //表格添加数据

{

QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);

int id = data(primaryKeyIndex).toInt(); //获取id号 也可以这样用,primaryKeyIndex.data();

clear();

bool isOk;

if (index.column() == 1) //第二个属性可更改

{

QSqlQuery query;

query.prepare("UPDATE STUDENT SET NAME = :name WHERE id = :id");

query.bindValue(":name","小五");

query.bindValue(":id",id);

isOk = query.exec();

refresh();// 此处最好添加代码刷新结果,或在此调用刷新函数

return isOK;

}

return false;

}

void MySqlQueryModel::refresh() //更新显示

{

setQuery("select * from student");

setHeaderData(0, Qt::Horizontal, QObject::tr("学号ID"));

setHeaderData(1, Qt::Horizontal, QObject::tr("名字"));

} //

//tata()改写某一个列的显示样式,对齐方式

QVariant MySqlQueryModel::data(const QModelIndex &index, int role) const

{

QVariant value = QSqlQueryModel::data(index, role);

if (role == Qt::TextColorRole && index.column() == 0)

return qVariantFromValue(QColor(Qt::red)); //第一个属性的字体颜色为红色

if (role == Qt::TextAlignmentRole && index.column() == 1)

{

value = (Qt::AlignVCenter + Qt::AlignRight); // 靠右垂直居中

}

return value;

}




推荐文章
评论(0)
联系我们|招贤纳士|移动客户端|风格模板|官方博客|侵权投诉 Reporting Infringements|未成年人有害信息举报 0571-89852053|涉企举报专区
网易公司版权所有 ©1997-2024  浙公网安备 33010802010186号 浙ICP备16011220号-11 增值电信业务经营许可证:浙B2-20160599
网络文化经营许可证: 浙网文[2022]1208-054号 自营经营者信息 工业和信息化部备案管理系统网站 12318全国文化市场举报网站
网信算备330108093980202220015号 网信算备330108093980204230011号
分享到
转载我的主页