版权声明:本文为博主原创文章,未经博主允许不得转载。 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;
}