我在 PostgreSQL 视图上使用 QSqlTableModel 时遇到了问题。让我先在这里显示相关代码。
使用在 PostgreSQL 9.2.4 上运行的以下代码创建一个视图:
CREATE OR REPLACE VIEW reporters_spaces_edit AS
SELECT reporters.name AS reporter_name, spaces.name AS space_name,
reporters_spaces.reporter_id IS NOT NULL AND reporters_spaces.space_id IS NOT NULL AS linked
FROM reporters
CROSS JOIN spaces
LEFT JOIN reporters_spaces ON reporters.id = reporters_spaces.reporter_id AND reporters_spaces.space_id = spaces.id;
我在 VC2005 上使用 Qt 4.4.0 编译的 C++ 代码如下所示:
void populateModel()
{
QTableView lrView;
QSqlDatabase lrDb(QSqlDatabase::addDatabase("QPSQL"));
...
QSqlTableModel lrModel(lrDb);
lrModel.setTable("reporters_spaces_edit");
if (!lrModel.select())
{
QMessageBox::critical(
0,
tr("Database Error"),
lrModel.lastError().text());
return;
}
lrView.setModel(lrModle);
}
它在消息框上显示“无法找到表记者空间编辑”。
我试图找出数据库中的所有视图。我添加了以下行:
QPlainTextEdit lrEdit;
lrEdit->setPlainText(lrDb.table(QSql::Views).join("\n"));
结果列表与
QPlainTextEdit lrEdit;
lrEdit->setPlainText(lrDb.table(QSql::Tables).join("\n"));
这是否意味着在 PostgreSQL 上运行时 QSqlTableModel 不支持 SQL 视图?
非常感谢!