为了加快速度,QComboBox使用非常大的数据集,希望尝试使用QSqlQueryModel而不是QStandardItemModel。但是,QComboBox中的文本数据需要映射到ID,该ID目前由itemData(rowIndex, Qt::UserRole)存储和访问。在QSqlQueryModel查询中,将有两个列: ID和Text;定义了QComboBox setModelColumn(1),即文本。
如果QSqlQueryModel必须包含ID,如何正确地子类或重新定义combobox->itemData(rowIndex, Qt::UserRole)?谁已经实现了这样的事情或知道链接到一个来源?如果我以这样的方式定义QVariant QSqlQueryModel::data(const QModelIndex & item, int role = Qt::DisplayRole):
QVariant MySqlModel::data(const QModelIndex &index, int role) const
{
if(role == Qt::UserRole && index.column() == 1)
return QSqlQueryModel::data(this->index(index.row(), 0), Qt::DisplayRole);
return QSqlQueryModel::data(index, role);
}它能工作吗,即在这种情况下,combobox->itemData(rowIndex, Qt::UserRole)是否包含ID?还是需要调查Qt的来源?
发布于 2015-09-19 22:27:44
是的,根据QComboBox代码应该可以:
QVariant QComboBox::itemData(int index, int role) const
{
Q_D(const QComboBox);
QModelIndex mi = d->model->index(index, d->modelColumn, d->root);
return d->model->data(mi, role);
}将实现这一点。
https://stackoverflow.com/questions/32672625
复制相似问题