Access qtableview qsqltablemodel from slot
Access qtableview qsqltablemodel from slot
我看过很多讨论类似问题的教程/解释,但我不知道如何把它应用到这种情况下。
我是一个Qt/c++新手,并试图建立简单的GUI应用程序,连接到一个SQLite数据库。我有UI表单,这是使用Qt Creator设计器构建的。
UI表单包含QTableView小部件,连接到我的表-所有似乎工作良好。
我也有一个按钮,应该-最终-添加一行表。我读到,我不应该运行"INSERT"查询,而是使用QSqlTableModel暴露的方法。不幸的是,我不能从slot访问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 model = ui->myTableView->model();
我明白这个问题-我知道我可以将QAbstractItemModel转换为SQLTableModel,但这似乎是一种变通方法,而不是正确的解决方案。
你能告诉我,我应该如何/在哪里声明/定义/实例化我的对象吗?这样我就可以访问QSqlTableModel从提到的槽向我的TableView提供数据?
谢谢你的帮助,Jim——事实是,我犯了一个愚蠢的错误:我不知道,我需要声明指针到我的模型在类的头文件:
private:
QSqlTableModel *model;
就是这样。
如我所说- c++新手。
您可以将模型保留为MainWindow成员数据并从插槽访问它,或者qobject_cast<QSqlTableModel*>(model())
并检查指针不为空。
或者甚至删除on_pushButtonAdd_clicked()方法并直接将按钮事件连接到模型插入方法(如果需要的话使用lambda),尽管这可能不是使用Qt开始的更好方法(因为当两个对象中的一个被删除时插槽连接会自动断开,而连接到lambdas则不会,因此更不容易出错)。
- 如何解决"invalid conversion from 'char' to 'const char*'"
- std::async from std::async in windows xp
- std::is_reference from std::any
- std::time_point from and to std::string
- "No suitable conversion function from 'std::string' to 'const char *' exists"
- std::chrono::time_point from std::string
- Visual accept std::string from std::byte iterator
- C++中链表的错误"Abort signal from abort(3) (sigabrt) "
- dopen():不以 root 身份运行时"failed to map segment from shared object"
- C++ 中的"template <typename From, typename Tag> struct Alias;"是什么?
- from std::vector to adept::avector
- Qt的slot(?)将冗余命名空间插入连接
- qt get child (Callout) from QChart
- Webassembly from Javascript
- Generate boost::uuids::uuid from boost::compute::detail::sha
- 什么是"Reading unbounded stream from standard input (Memory Management)"的例子
- Calling C++ dll from python
- 为什么我会收到"invalid conversion from 'Queue*/Stack*' to 'int'"错误消息?
- std::chrono 在从 main 或 from 类方法使用时给出不同的值
- Access qtableview qsqltablemodel from slot