从插槽访问 qtableview qsqltablemodel
Access qtableview qsqltablemodel from slot
我看过很多讨论类似问题的教程/解释,
但我不知道如何将其应用于这种情况。
我是一个 Qt/C++ 新手,正在尝试开发一个简单的 GUI 应用程序,它连接到一个
SQLite 数据库。我有 UI 表格,那是 built 使用 Qt Creator 设计器。
UI 表单包含连接到我的 table 的 QTableView 小部件 - 似乎一切正常。
我还有一个按钮,它最终应该向 table 添加一行。
我读过,我不应该 运行 “INSERT” 查询,而是使用 QSqlTableModel 公开的方法。
很遗憾,我无法从插槽访问我的 TableView 数据模型。
这是我的代码:
1) mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QDebug>
#include <QtSql>
#include <QFileInfo>
namespace Ui {
class MainWindow;
}
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
explicit MainWindow(QWidget *parent = 0);
~MainWindow();
private slots:
void on_pushButtonChange_clicked();
void on_pushButtonAdd_clicked();
private:
Ui::MainWindow *ui;
QSqlDatabase db;
};
#endif // MAINWINDOW_H
2) main.cpp
#include "mainwindow.h"
#include <QApplication>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;
w.show();
return a.exec();
}
3) mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
QString dbType = "QSQLITE";
QString dbName = “my.db";
QString dbTable = “myTable”;
db = QSqlDatabase::addDatabase(dbType);
db.setDatabaseName(dbName);
db.open();
QSqlTableModel *model = new QSqlTableModel(this, db);
model->setTable(dbTable);
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
model->select();
ui->myTableView->setModel(model);
}
MainWindow::~MainWindow()
{
delete ui;
}
void MainWindow::on_pushButtonAdd_clicked()
{
//This is just to show, that I want to access QSqlTableModel from here:
QSqlTableModel model = ui->myTableView->model();
}
当我 运行 调试时,我收到以下错误消息:
错误:无法从 'QAbstractItemModel *' 转换为 'QSqlTableModel'
QSqlTableModel 模型 = ui->myTableView->model();
我明白这个问题 - 我知道我可以将 QAbstractItemModel 转换为 SQLTableModel,
但这似乎是一种解决方法,而不是正确的解决方案。
能否请您指教,how/where 我应该 declare/define/instantiate 我的对象,
这样我就可以访问 QSqlTableModel 从提到的 Slot 向我的 TableView 提供数据?
您可以将模型保留为 MainWindow 成员数据并从槽中访问它,或者 qobject_cast<QSqlTableModel*>(model())
并检查指针是否为空。
甚至删除 on_pushButtonAdd_clicked() 方法并将按钮事件直接连接到模型插入方法(如果需要,使用 lambda),尽管这可能不是开始使用 Qt 的更好方法(因为插槽当两个对象之一被删除时,连接会自动断开,而与 lambda 的连接则不会,因此更不容易出错。
感谢您的帮助,吉姆 - 事实上,我犯了一个愚蠢的错误:
我不知道,我需要在 class' 头文件中声明指向我的模型的指针:
private:
QSqlTableModel *model;
就是这样。
正如我所说 - C++ 新手。对不起...
我看过很多讨论类似问题的教程/解释, 但我不知道如何将其应用于这种情况。
我是一个 Qt/C++ 新手,正在尝试开发一个简单的 GUI 应用程序,它连接到一个 SQLite 数据库。我有 UI 表格,那是 built 使用 Qt Creator 设计器。
UI 表单包含连接到我的 table 的 QTableView 小部件 - 似乎一切正常。
我还有一个按钮,它最终应该向 table 添加一行。 我读过,我不应该 运行 “INSERT” 查询,而是使用 QSqlTableModel 公开的方法。 很遗憾,我无法从插槽访问我的 TableView 数据模型。
这是我的代码:
1) mainwindow.h
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
#include <QMainWindow>
#include <QDebug>
#include <QtSql>
#include <QFileInfo>
namespace Ui {
class MainWindow;
}
class MainWindow : public QMainWindow
{
Q_OBJECT
public:
explicit MainWindow(QWidget *parent = 0);
~MainWindow();
private slots:
void on_pushButtonChange_clicked();
void on_pushButtonAdd_clicked();
private:
Ui::MainWindow *ui;
QSqlDatabase db;
};
#endif // MAINWINDOW_H
2) main.cpp
#include "mainwindow.h"
#include <QApplication>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
MainWindow w;
w.show();
return a.exec();
}
3) mainwindow.cpp
#include "mainwindow.h"
#include "ui_mainwindow.h"
MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent),
ui(new Ui::MainWindow)
{
ui->setupUi(this);
QString dbType = "QSQLITE";
QString dbName = “my.db";
QString dbTable = “myTable”;
db = QSqlDatabase::addDatabase(dbType);
db.setDatabaseName(dbName);
db.open();
QSqlTableModel *model = new QSqlTableModel(this, db);
model->setTable(dbTable);
model->setEditStrategy(QSqlTableModel::OnManualSubmit);
model->select();
ui->myTableView->setModel(model);
}
MainWindow::~MainWindow()
{
delete ui;
}
void MainWindow::on_pushButtonAdd_clicked()
{
//This is just to show, that I want to access QSqlTableModel from here:
QSqlTableModel model = ui->myTableView->model();
}
当我 运行 调试时,我收到以下错误消息:
错误:无法从 'QAbstractItemModel *' 转换为 'QSqlTableModel' QSqlTableModel 模型 = ui->myTableView->model();
我明白这个问题 - 我知道我可以将 QAbstractItemModel 转换为 SQLTableModel, 但这似乎是一种解决方法,而不是正确的解决方案。
能否请您指教,how/where 我应该 declare/define/instantiate 我的对象, 这样我就可以访问 QSqlTableModel 从提到的 Slot 向我的 TableView 提供数据?
您可以将模型保留为 MainWindow 成员数据并从槽中访问它,或者 qobject_cast<QSqlTableModel*>(model())
并检查指针是否为空。
甚至删除 on_pushButtonAdd_clicked() 方法并将按钮事件直接连接到模型插入方法(如果需要,使用 lambda),尽管这可能不是开始使用 Qt 的更好方法(因为插槽当两个对象之一被删除时,连接会自动断开,而与 lambda 的连接则不会,因此更不容易出错。
感谢您的帮助,吉姆 - 事实上,我犯了一个愚蠢的错误: 我不知道,我需要在 class' 头文件中声明指向我的模型的指针:
private:
QSqlTableModel *model;
就是这样。
正如我所说 - C++ 新手。对不起...