首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从插槽访问qtableview qsqltablemodel

从插槽访问qtableview qsqltablemodel
EN

Stack Overflow用户
提问于 2015-09-05 12:34:34
回答 2查看 524关注 0票数 1

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

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

UI表单包含连接到我的表上的QTableView小部件--看起来一切正常。

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

这是我的代码:

1)主窗口.h

代码语言:javascript
复制
#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

代码语言:javascript
复制
#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

代码语言:javascript
复制
#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->QSqlTableModel()之间没有可行的转换;

我理解这个问题--我知道我可以将QAbstractItemModel转换为SQLTableModel,但这似乎是一种解决办法,而不是正确的解决方案。

请您告诉我,我应该如何/在哪里声明/定义/实例化我的对象,这样我就可以从上面提到的插槽访问QSqlTableModel向TableView提供数据了吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-09-05 22:30:27

您可以将模型保留为MainWindow成员数据并从槽中访问它,或者qobject_cast<QSqlTableModel*>(model())和check指针不为空。

甚至删除on_pushButtonAdd_clicked()方法并将按钮事件直接连接到模型插入方法(如果需要的话使用lambda ),尽管这可能不是从Qt开始的更好的方法(因为当两个对象中的一个被删除时,插槽连接是自动断开的,而指向lambdas的连接不是,因此不容易出错)。

票数 0
EN

Stack Overflow用户

发布于 2015-09-22 08:53:33

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

代码语言:javascript
复制
private:
    QSqlTableModel *model;

仅此而已。

就像我说的- C++新手。很抱歉..。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32413105

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档