Qt工作笔记-MySQL获取select表头(域)数据

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq78442761/article/details/89263420

比如在开发的时候使用select但要提取域数据(基本上是二次开发的时候用)

如下:

如何使用Qt获取id,name,cardId,gender,major,birth的数据!

使用QSqlRecord即可!

如下运行截图:

程序结构如下:

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QSqlDatabase>

namespace Ui {
class Widget;
}

class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = 0);
    ~Widget();

private:
    Ui::Widget *ui;
    QSqlDatabase m_db;
};

#endif // WIDGET_H

main.cpp

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

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();

    return a.exec();
}

widget.cpp

#include "widget.h"
#include "ui_widget.h"
#include <QDebug>
#include <QSqlResult>
#include <QSqlQuery>
#include <QSqlRecord>

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

    m_db = QSqlDatabase::addDatabase("QMYSQL");
    m_db.setHostName("127.0.0.1");
    m_db.setPort(3306);
    m_db.setDatabaseName("gradb");
    m_db.setUserName("root");
    m_db.setPassword("root");

    if(!m_db.open()){

        qDebug() << "error";
        return;
    }

    m_db.exec("SET NAMES 'gbk'");

    QString cmd = "SELECT * FROM gradb.`student`";
    QSqlQuery sqlQuery;
    if(!sqlQuery.exec(cmd))
        return;

    QStringList headList;
    QSqlRecord sqlRecord(sqlQuery.record());
    for(int i = 0; i < sqlRecord.count(); i++){

        headList << sqlRecord.fieldName(i);
    }

    qDebug() << headList;

    while(sqlQuery.next()){

        for(int i = 0; i < headList.size(); i++){

            qDebug() << sqlQuery.value(headList[i]);
        }
    }
}

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

猜你喜欢

转载自blog.csdn.net/qq78442761/article/details/89263420