1

同様の問題について説明している多くのチュートリアル/説明を見てきましたが、この状況に適用する方法がわかりません。

私は Qt/C++ の初心者で、SQLite データベースに接続する単純な GUI アプリケーションを構築しようとしています。Qt Creator デザイナーを使用して構築された UI フォームがあります。

UI フォームには、テーブルに接続されている QTableView ウィジェットが含まれています - すべて正常に動作しているようです。

また、最終的にテーブルに行を追加するプッシュボタンもあります。「INSERT」クエリを実行するのではなく、代わりに 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 モデル = ui->myTableView->model();

私は問題を理解しています - QAbstractItemModel を SQLTableModel にキャストできることは知っていますが、これは適切な解決策ではなく回避策のようです。

上記のスロットから TableView にデータを供給する QSqlTableModel にアクセスできるように、オブジェクトを宣言/定義/インスタンス化する方法/場所を教えてください。

4

2 に答える 2

1

助けてくれてありがとうジム - 実は、私はばかげた間違いを犯しました: クラスのヘッダーファイルでモデルへのポインタを宣言する必要があることを知りませんでした:

private:
    QSqlTableModel *model;

以上です。

私が言ったように - C++初心者。そのために残念...

于 2015-09-22T08:53:33.427 に答える
0

モデルを MainWindow メンバー データとして保持し、スロットからアクセスするかqobject_cast<QSqlTableModel*>(model())、ポインターが null でないことを確認します。

または、on_pushButtonAdd_clicked() メソッドを削除して、ボタン イベントをモデルの挿入メソッドに直接接続する (必要に応じてラムダを使用) こともできますが、これはおそらく Qt で開始するより良い方法ではありません (スロット接続は、2 つのうちの 1 つが実行されると自動的に切断されるため)。オブジェクトは削除されますが、ラムダへの接続は削除されないため、エラーが発生しにくくなります)。

于 2015-09-05T22:30:27.370 に答える