同様の問題について説明している多くのチュートリアル/説明を見てきましたが、この状況に適用する方法がわかりません。
私は 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 にアクセスできるように、オブジェクトを宣言/定義/インスタンス化する方法/場所を教えてください。