QT tableview问题

使用QT制作学生管理系统时,执行刷新或修改tableview后,tableview会变空白,控制台会输出

QSqlQuery::prepare: database not open
QSqlQuery::exec: database not open

但是刚进入界面时tableview有内容
贴上代码,还请各位帮忙解决

#ifndef INFOWINDOW_H
#define INFOWINDOW_H

#include <QWidget>
#include <QDebug>
#include <QString>
#include <QMessageBox>
#include "mydatabase.h"
#include "addstudent.h"
#include "deletestu.h"

namespace Ui {
class infowindow;
}

class infowindow : public QWidget
{
    Q_OBJECT

public:
    explicit infowindow(QWidget *parent = nullptr);
    ~infowindow();

private slots:
    void on_pushButton_clicked();

    void on_pushButton_3_clicked();

    void on_pushButton_2_clicked();

    void on_pushButton_4_clicked();

private:
    Ui::infowindow *ui;
    addstudent *a = new addstudent();
    deletestu *d = new deletestu();
    QSqlDatabase& db_info = Mydatabase::getDatabase();
    QSqlTableModel *m = new QSqlTableModel(this);
};

#endif // INFOWINDOW_H
//此节目头文件
#include "infowindow.h"
#include "ui_infowindow.h"

infowindow::infowindow(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::infowindow)
{
    ui->setupUi(this);
    if(!db_info.open())
    {
        qDebug()<<"error";
    }
    m = new QSqlTableModel;
    m->setTable("base_infomation");
    m->select();
    ui->tableView->setModel(m);
}

infowindow::~infowindow()
{
    db_info.close();
    delete ui;
    delete a;
    delete d;
}

void infowindow::on_pushButton_clicked()
{
    a->show();
}

void infowindow::on_pushButton_3_clicked()
{
    m->select();
    ui->tableView->setModel(m);
}

void infowindow::on_pushButton_2_clicked()
{
    d->show();
}

void infowindow::on_pushButton_4_clicked()
{
    QString search_name = ui->searchline->text();
    m->setFilter(search_name);
    m->select();
    ui->tableView->setModel(m);
}
//此界面代码实现
QSqlDatabase& Mydatabase::getDatabase()
{
    if(!db.isValid())
    {
        db = QSqlDatabase::addDatabase("QMYSQL");
        db.setHostName("localhost");
        db.setPort(3306);
        db.setDatabaseName("students");
        db.setUserName("root");
        db.setPassword("PASSWORD");
    }

    return db;
}

//mydatabse类的实现

和db声明的位置有关吧..
类似这个博客里的https://blog.csdn.net/haigear/article/details/120416960

不知道你这个问题是否已经解决, 如果还没有解决的话:
  • 你可以看下这个问题的回答https://ask.csdn.net/questions/715696
  • 这篇博客你也可以参考下:QT tableview 怎样判断是否为空?
  • 除此之外, 这篇博客: QT tableview列宽随窗口改变中的 QT4代码 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:
    //QT4
    //列宽随窗口大小改变而改变,每列平均分配,充满整个表,但是此时列宽不能拖动进行改变
           ui->tableView->horizontalHeader()->setResizeMode(QHeaderView::Stretch);
    
           //第四列和第五列适应内容长短分配大小(从0开始计数)
           ui->tableView->horizontalHeader()->setResizeMode(4,QHeaderView::ResizeToContents);
           ui->tableView->horizontalHeader()->setResizeMode(5,QHeaderView::ResizeToContents);
    
    
  • 您还可以看一下 代轩老师的C++ Qt编程课程中的 QTableView 表格控件小节, 巩固相关知识点

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^