QT版本是QT5.9.9,编译器是32
位的,数据库是5.7.38 32
位的,位数一定要匹配
否则无法连接数据库。
QT += core gui sql
在.cpp的文件直接添加如下代码。
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include
#include
#include
#include
#include
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路径下,完成数据库连接
连接成功,打印如下内容。
查询数据库中的数据,可以直接使用如下模板
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条)