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();
因为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 )
-
{
-
QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);
-
int id = data(primaryKeyIndex).toInt();
-
-
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("名字"));
-
}
-
-
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;
-
}
转自:
http://blog.csdn.net/reborntercel/article/details/7000220
阅读(9726) | 评论(0) | 转发(1) |