Qt Creator 使用QTableView來顯示MySql數據庫表中的數據

1.使用Qt Creater新建一個Qt Widgets Application,文檔結構如下圖所示;

2.創建界面如下所示:

3.其中mainwindow.h中的代碼如下:

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>
#include <QSqlTableModel>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();
    static bool connectDB();
   // void shuchu();

private slots:
    //void on_pushButton_clicked();

    void on_query_clicked();

private:
    Ui::MainWindow *ui;
    QSqlTableModel *model;
};
#endif // MAINWINDOW_H

其中mainwindow.cpp中的代碼如下:

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include "QSqlDatabase"
#include "QMessageBox"
#include "QSqlError"
#include "QDebug"
#include <iostream>
using namespace std;

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
}

MainWindow::~MainWindow()
{
    delete ui;
}

 bool MainWindow::connectDB()
{
    QSqlDatabase db=QSqlDatabase::addDatabase("QMYSQL");
    db.setHostName("localhost");
    db.setUserName("root");
    db.setPassword("root");
    db.setDatabaseName("lab123");
    if(!db.open())
    {
        //MainWindow::on_pushButton_clicked();
       // QMessageBox::warning(this,"wrong",db.lastError().text());
        return false;
    }
    else
    {
        return true;
    }

}

void MainWindow::on_query_clicked()
{
   static QSqlQueryModel *mode= new QSqlQueryModel(ui->tableView);

    mode->setQuery("select * from equip");
    mode->setHeaderData(0,Qt::Horizontal,tr("id"));
    mode->setHeaderData(1, Qt::Horizontal, tr("name"));
    ui->tableView->setModel(mode);
}
 

 

其中main.cpp中的代碼如下:

#include "mainwindow.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    MainWindow w;
    w.connectDB();
    w.show();
    return a.exec();
}

4.運行程序,點擊query會出現顯示效果:

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章