编译Qt6.5.3LTS版本(Mac/Windows)的mysql驱动(附带编译后的全部文件)

文章目录

  • [0 背景](#0 背景)
  • [1 编译过程](#1 编译过程)
  • [2 福利](#2 福利)
  • 参考

0 背景

因为项目要用到对MYSQL数据库操作,所以需要连接到MYSQL数据库。但是连接需要MYSQL驱动,但是Qt本身不自带MYSQL驱动,需要自行编译。网上有很多qt之前版本的mysql驱动,但是没有找到qt6.5.3版本的,所以只好自己编译。

编译好的文件如下:

1 编译过程

1,如果没有下载qt源代码的,可以通过在终端运行下面的指令,

  • windows:.\MaintenanceTool.exe --mirror https://mirror.nju.edu.cn/qt;
  • Mac:./MaintenanceTool.app/Contents/MacOS/MaintenanceTool --mirror https://mirror.nju.edu.cn/qt

如果不需要更换镜像,可以不加--mirror https://mirror.nju.edu.cn/qt


2,打开mysql驱动编译程序/Users/mac/Qt6.5/6.5.3/Src/qtbase/src/plugins/build-sqldrivers-Qt_6_5_3_for_macOS-Release/CMakeCache.txt

mac:

windwos:

3,修改/Users/mac/Qt6.5/6.5.3/Src/qtbase/src/plugins/CMakeLists.txt文件;

mac:

cpp 复制代码
SET(FEATURE_sql_mysql ON)
SET(MySQL_INCLUDE_DIR "/usr/local/Cellar/mysql@5.7/5.7.44_1/include/mysql")
SET(MySQL_LIBRARY "/usr/local/Cellar/mysql@5.7/5.7.44_1/lib/libmysqlclient.20.dylib")

windows:

cpp 复制代码
SET(FEATURE_sql_mysql ON)
SET(MySQL_INCLUDE_DIR "D:/mysql-8.0.36-winx64/include")
SET(MySQL_LIBRARY "D:/mysql-8.0.36-winx64/lib/libmysql.dll")
  • mac下载mysql
cpp 复制代码
brew uninstall mysql
brew cleanup --prune=all mysql
rm -rf /usr/local/var/mysql
brew install mysql@5.7

4,然后编译程序,得到编译后的mysql驱动;

mac:

windows:

虽然会报错,但是还是可以成功编译出mysql驱动。

5,把编译好的驱动程序放到/Users/mac/Qt6.5/6.5.3/macos/plugins/sqldrivers文件夹中;

mac(编译好的文件,存在的位置):

windows(编译好的文件,存在的位置):

如果是windwos,还需要把下面的两个文件放入到D:\Qt\Qt5.15.2\6.5.3\mingw_64\bin中。

6,编写程序测试驱动。

cpp 复制代码
#include "mainwindow.h"

#include <QApplication>
#include <QSqlDatabase>
#include <QDebug>


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

    qDebug()<<"查看目前可用驱动";
    QStringList drivers = QSqlDatabase::drivers();
    for(auto driver: drivers){
        qDebug()<<driver<<" ";
    }

    //设置数据库驱动
    QSqlDatabase db1 = QSqlDatabase::addDatabase("QMYSQL", "connection1");
    db1.setHostName("192.168.0.104");
    db1.setUserName("root");
    db1.setPassword("password");
    db1.setPort(3309);
    db1.setDatabaseName("test_db");

    if(db1.open()){
        qDebug()<<"数据库打开成功";
    }

    return a.exec();


}

得到如下结果:

mac:

windwos:

2 福利

编译好的mysql驱动,含windows和mac版本的(5.14.2,5.15.2,6.5.3),链接如下:

链接:https://pan.baidu.com/s/1m15DbFuFTtXfEyqyOS2cew

提取码: 2o2s

参考

https://blog.csdn.net/m0_52072919/article/details/130094915

https://blog.csdn.net/weixin_53989417/article/details/132586266

相关推荐
翻斗包菜8 小时前
第 03 章 Python 操作 MySQL 数据库实战全解
数据库·python·mysql
SPC的存折8 小时前
1、MySQL故障排查与运维案例
linux·运维·服务器·数据库·mysql
悟空码字8 小时前
MySQL性能优化的天花板:10条你必须掌握的顶级SQL分析技巧
java·后端·mysql
十五年专注C++开发8 小时前
cpolar(极点云): 一款主流的内网穿透工具
linux·windows·cpolar·穿透
鬼先生_sir8 小时前
MySQL进阶-事务与锁机制
数据库·mysql·mvcc
非凡ghost8 小时前
AIMP(音乐播放软件)
前端·windows·音视频·firefox
xifangge20258 小时前
【2026终极解法】彻底解决“由于找不到 msvcp140.dll,无法继续执行代码”报错(附微软运行库一键修复包)
windows·mysql·microsoft·报错·开发环境
摇滚侠8 小时前
Windows 查看占用端口的进程,并关闭进程
windows
汤姆yu9 小时前
Windows系统下TRAE的安装与完整使用教程
windows·ai·trae·ai编程工具
一个人旅程~9 小时前
macOS装进移动硬盘成为双系统的操作方法
linux·经验分享·macos·电脑