QT连接数据库

QT版本是QT5.9.9,编译器是32位的,数据库是5.7.38 32位的,位数一定要匹配否则无法连接数据库。

QT       += core gui sql

在.cpp的文件直接添加如下代码。

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QSqlDatabase>
#include <QMessageBox>
#include <QSqlDatabase>
#include <QSqlError>
#include <QDebug>


MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    QStringList list = QSqlDatabase::drivers();
        qDebug() << list;

        QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL");
        if(db.isValid())
        {
            QMessageBox::information(this, "conn", "ok");
        }
        else
        {
            QMessageBox::information(this, "conn", "error");
        }
        db.setHostName("127.0.0.1"); // 本地连接
        db.setPort(3306);       // 如果使用的是默认端口可以不设置
        db.setUserName("root");	// 数据库用户名
        db.setPassword("quan"); // 数据库密码
        db.setDatabaseName("mysql"); // 数据库名字
        if(db.open())
        {
            QMessageBox::information(this, "打开数据库", "数据库打开成功, 可以读写数据了......");
        }
        else
        {
            QString msg = "数据库打开失败: " + db.lastError().text();
            QMessageBox::information(this, "打开数据库", msg);
        }


}

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


如果出现如下错误
在这里插入图片描述是没有myqsql的库,进行如下操作,把mysql安装目录下的libmysql.dll在这里插入图片描述复制到QT的bin路径下,完成数据库连接在这里插入图片描述

连接成功,打印如下内容。
在这里插入图片描述
在这里插入图片描述

QT数据库查询操作

查询数据库中的数据,可以直接使用如下模板

QSqlQuery query;
        QString sql =  "select * from pressdata_table";
        //重载函数
        query.exec(sql);
        while (query.next()) {
            //取出字段的数值
            qDebug()<< query.value(0).toString()
                    <<query.value(1).toInt()
                    <<query.value(2).toInt()
                    <<query.value("AC1press").toInt()
                    <<query.value("AC2press").toInt()
                    <<query.value("ASPress").toInt()
                    <<query.value("SRpress").toInt()
                    <<query.value("BCPress").toInt();
        }

在这里插入图片描述

QT向数据库写入操作(QT事务操作)

数据的插入、更新、删除。数据库写操作的时候创建事务。

QSqlQuery query;
         QString sql =  QString("insert into pressdata_table (time,VLpress,AC1press,AC2press,ASPress,SRpress,BCpress) "
                                "values  ('2022.5.3','%1','%2','%3','%4','%5','%6')")
                                                        .arg(VLpress).arg(AC1press).arg(AC2press).arg(ASPress).arg(SRpress).arg(BCpress);
         db.transaction();
         bool flag = query.exec(sql);
         if(flag){
             db.commit();
         }
         else {
             db.rollback();
         }

在这里插入图片描述

  • 0
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值