从插槽

时间:2015-09-05 12:34:34

标签: c++ qt qtableview qsqltablemodel

我看过很多讨论类似问题的教程/解释, 但我无法弄清楚,如何将它应用于这种情况。

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

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

我还有一个按钮,应该 - 最终 - 在表中添加一行。 我已经读过,我不应该运行“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();

}

当我运行调试时,我收到以下错误消息:

错误:没有可靠的转换来自&#39; QAbstractItemModel *&#39;到了QSqlTableModel&#39;     QSqlTableModel model = ui-&gt; myTableView-&gt; model();

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

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

2 个答案:

答案 0 :(得分:0)

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

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

答案 1 :(得分:0)

谢谢你的帮助吉姆 - 事实是,我犯了一个愚蠢的错误: 我不知道,我需要在课堂上声明指向我模特的指针。头文件:

private:
    QSqlTableModel *model;

那就是它。

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