gpt4 book ai didi

c++ - 从插槽访问 qtableview qsqltablemodel

转载 作者:行者123 更新时间:2023-11-30 05:39:21 24 4
gpt4 key购买 nike

我看过很多讨论类似问题的教程/解释,但我不知道如何将其应用于这种情况。

我是一名 Qt/C++ 新手,正在尝试构建连接到一个简单的 GUI 应用程序SQLite 数据库。我有 UI 表单,它是使用 Qt Creator 设计器构建的。

UI 表单包含连接到我的表的 QTableView 小部件 - 一切似乎都工作正常。

我还有一个按钮,它应该——最终——向表中添加一行。我读过,我不应该运行“插入”查询,而是使用 QSqlTableModel 公开的方法。不幸的是,我无法从插槽访问我的 TableView 数据模型。

这是我的代码:

1) 主窗口.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) 主窗口.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,将数据从提到的 Slot 提供给我的 TableView?

最佳答案

感谢 Jim 的帮助 - 事实上,我犯了一个愚蠢的错误:我不知道,我需要在类的头文件中声明指向我的模型的指针:

private:
QSqlTableModel *model;

就是这样。

正如我所说 - C++ 新手。对不起...

关于c++ - 从插槽访问 qtableview qsqltablemodel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32413105/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com