当前位置: 首页 > article >正文

Qt 5.15.2 手动编译MySQL驱动全攻略:从源码缺失到连接成功

1. 问题根源为什么Qt 5.15.2没有内置MySQL驱动第一次在Qt 5.15.2中使用QSqlDatabase连接MySQL数据库时看到QMYSQL driver not loaded这个错误提示很多开发者都会感到困惑。明明之前的Qt版本都能直接使用MySQL驱动为什么新版本就不行了呢这其实和Qt的商业策略变化有关。从Qt 5.15开始官方将MySQL驱动移出了默认的二进制发行包。这不是bug而是有意为之的设计变更。主要原因有两个一是MySQL的许可证问题二是减少默认发行包的体积。MySQL采用的是GPL许可证而Qt的商业版是闭源的这导致在分发预编译驱动时存在法律风险。我刚开始遇到这个问题时也很头疼特别是项目急着要对接MySQL数据库。后来发现解决方案其实很明确——需要手动编译MySQL驱动。这个过程虽然有点繁琐但一旦掌握了方法以后在任何环境下都能轻松应对。最重要的是手动编译能让你更深入地理解Qt的数据库驱动机制。2. 环境准备检查源码和安装必要组件2.1 确认Qt源码是否完整首先需要检查你的Qt安装是否包含完整的源码。打开Qt安装目录找到以下路径Qt/5.15.2/Src/qtbase/src/plugins/sqldrivers在这个目录下你应该能看到mysql文件夹。如果没有说明你的Qt安装可能只包含了预编译的二进制文件这时需要通过Qt维护工具(MaintenanceTool)下载源码组件。我建议在开始前先备份整个项目因为编译过程中会修改一些配置文件。另外确保你的Qt Creator使用的是和编译环境匹配的kit比如都是MinGW或都是MSVC否则编译出来的驱动可能无法使用。2.2 安装MySQL开发库要编译MySQL驱动我们需要MySQL的客户端开发库。前往MySQL官网下载社区版服务器选择适合你系统的版本。我使用的是MySQL 8.0.35 Windows x64版本下载后解压到合适的位置。关键是要获取以下文件libmysql.dll (位于bin目录)libmysql.lib (位于lib目录)mysql.h等头文件 (位于include目录)这些文件在编译过程中至关重要。我通常会把MySQL的整个解压目录放在Qt源码附近方便引用路径。记住这个位置后面配置.pro文件时会用到。3. 配置和修改项目文件3.1 修改mysql.pro文件打开mysql目录下的mysql.pro文件这是驱动编译的核心配置文件。需要做几处关键修改注释掉原有的INCLUDEPATH和LIBS配置添加你自己的MySQL库路径例如INCLUDEPATH D:/mysql-8.0.35-winx64/include LIBS D:/mysql-8.0.35-winx64/lib/libmysql.lib这里有个容易踩的坑路径中的斜杠方向。在Windows下Qt通常能识别正斜杠(/)和反斜杠()但为了跨平台兼容性建议统一使用正斜杠。3.2 调整qsqldriverbase.pri文件在同一个目录下找到qsqldriverbase.pri文件修改以下内容# 注释掉原来的include # include($$shadowed($$PWD)/qtsqldrivers-config.pri) # 添加新的include include(./configure.pri)这个修改是为了绕过Qt默认的驱动配置系统使用我们自定义的配置。保存文件后建议先执行qmake生成新的Makefile然后再开始编译。4. 编译驱动和解决常见问题4.1 执行编译过程在Qt Creator中打开mysql.pro项目选择Release模式进行编译。编译成功后你会在输出目录下看到两个关键文件qsqlmysql.dllqsqlmysql.dll.debug把这些文件复制到Qt的插件目录Qt/5.15.2/mingw81_64/plugins/sqldrivers如果使用MSVC编译器路径会有所不同需要对应到你的编译器版本目录下。4.2 处理环境变量问题即使编译成功有时还是会遇到驱动加载失败的情况。这通常是因为系统找不到MySQL的动态链接库。解决方法有两种将MySQL的bin目录添加到系统PATH环境变量中或者直接将libmysql.dll复制到你的应用程序输出目录我建议采用第一种方法因为它更彻底而且不会因为忘记复制dll而导致程序在其他机器上运行失败。5. 测试MySQL连接和基本操作5.1 建立数据库连接驱动编译完成后就可以在代码中使用QMYSQL驱动了。下面是一个完整的连接示例QSqlDatabase db QSqlDatabase::addDatabase(QMYSQL); db.setHostName(localhost); db.setPort(3306); // MySQL默认端口 db.setDatabaseName(test_db); db.setUserName(root); db.setPassword(yourpassword); if (!db.open()) { qDebug() 连接失败: db.lastError().text(); } else { qDebug() 连接成功!; }注意MySQL 8.0默认使用caching_sha2_password认证插件如果遇到认证问题可能需要修改用户密码为mysql_native_password方式ALTER USER usernamelocalhost IDENTIFIED WITH mysql_native_password BY password;5.2 执行SQL查询连接成功后就可以执行各种SQL操作了。下面是一个查询示例QSqlQuery query; query.prepare(SELECT id, name FROM users WHERE age ?); query.addBindValue(18); if (!query.exec()) { qDebug() 查询失败: query.lastError().text(); } else { while (query.next()) { int id query.value(0).toInt(); QString name query.value(1).toString(); qDebug() ID: id Name: name; } }使用预处理语句(query.prepare)和参数绑定(addBindValue)可以有效防止SQL注入这是数据库编程中的最佳实践。6. 高级技巧和性能优化6.1 连接池管理对于需要频繁建立和关闭连接的应用使用连接池可以显著提高性能。Qt虽然没有内置连接池但可以自己实现一个简单的版本QListQSqlDatabase connectionPool; // 初始化连接池 for (int i 0; i 5; i) { QSqlDatabase db QSqlDatabase::addDatabase(QMYSQL, QString(conn_%1).arg(i)); // 配置连接参数... if (db.open()) { connectionPool.append(db); } } // 获取连接 QSqlDatabase getConnection() { if (connectionPool.isEmpty()) { qDebug() 没有可用连接!; return QSqlDatabase(); } return connectionPool.takeFirst(); } // 释放连接 void releaseConnection(QSqlDatabase db) { connectionPool.append(db); }6.2 批量插入优化当需要插入大量数据时逐条执行INSERT语句效率很低。MySQL支持批量插入语法QSqlQuery query; query.prepare(INSERT INTO users (name, age) VALUES (?, ?)); QVariantList names, ages; names Alice Bob Charlie; ages 25 30 28; query.addBindValue(names); query.addBindValue(ages); if (!query.execBatch()) { qDebug() 批量插入失败: query.lastError().text(); }这种方法比循环执行单条INSERT语句快得多特别是在处理成千上万条记录时。7. 跨平台注意事项7.1 Linux/macOS下的编译差异在Linux和macOS上编译MySQL驱动过程与Windows类似但有几点需要注意MySQL开发包通常可以通过包管理器安装Ubuntu/Debian:sudo apt-get install libmysqlclient-devCentOS/RHEL:sudo yum install mysql-develmacOS:brew install mysql在.pro文件中链接库的名称可能不同LIBS -lmysqlclient动态库路径问题Linux下可能需要设置LD_LIBRARY_PATHmacOS下可能需要设置DYLD_LIBRARY_PATH。7.2 部署时的依赖处理当分发你的应用程序时记得包含以下依赖项qsqlmysql.dll (Qt MySQL驱动)libmysql.dll (MySQL客户端库)相关的Qt核心DLL在Linux上可以使用ldd命令检查可执行文件的依赖关系ldd your_app | grep mysql对于macOS可以使用otoolotool -L your_app | grep mysql8. 故障排除和调试技巧8.1 常见错误解决方案QMYSQL driver not loaded确认驱动DLL在正确的plugins/sqldrivers目录检查应用程序是否找到了MySQL客户端库Authentication plugin caching_sha2_password cannot be loaded修改MySQL用户使用mysql_native_password认证方式或者在连接字符串中添加MYSQL_OPT_GET_SERVER_PUBLIC_KEY1Cant connect to MySQL server on localhost确认MySQL服务正在运行检查防火墙设置尝试使用127.0.0.1代替localhost8.2 启用SQL调试输出在开发阶段可以启用Qt的SQL调试信息来帮助排查问题QLoggingCategory::setFilterRules(qt.sqltrue);这会在应用程序输出中显示所有SQL查询和错误信息对于调试复杂的数据库问题非常有用。9. 替代方案和未来展望9.1 使用其他数据库驱动如果MySQL驱动问题实在难以解决可以考虑其他数据库选项SQLiteQt内置支持无需额外驱动PostgreSQLQt也提供了QPSQL驱动ODBC通用数据库接口但性能可能较差9.2 Qt 6中的变化在Qt 6中数据库驱动的处理方式有所改变。好消息是MySQL驱动又回到了默认的二进制包中但编译过程基本保持不变。如果你将来迁移到Qt 6可以继续使用这些知识。手动编译MySQL驱动的过程虽然有点复杂但掌握后你会发现这其实是一项很有价值的技能。我在多个项目中都遇到过类似的问题每次解决后都对Qt的数据库系统有了更深的理解。最重要的是这个过程教会了我如何查阅官方文档和源码来解决问题——这在开发者的成长道路上是非常重要的一课。

相关文章:

Qt 5.15.2 手动编译MySQL驱动全攻略:从源码缺失到连接成功

1. 问题根源:为什么Qt 5.15.2没有内置MySQL驱动 第一次在Qt 5.15.2中使用QSqlDatabase连接MySQL数据库时,看到"QMYSQL driver not loaded"这个错误提示,很多开发者都会感到困惑。明明之前的Qt版本都能直接使用MySQL驱动&#xff0c…...

C++编写百万QPS MCP网关的5个反直觉陷阱:90%团队在第3步就发生连接雪崩

更多请点击: https://intelliparadigm.com 第一章:C编写百万QPS MCP网关的底层性能认知重构 传统网关性能瓶颈常被归因于线程模型或协议解析,但真实制约百万级QPS的核心在于**内存访问模式、缓存行竞争与内核旁路路径的协同失效**。在MCP&am…...

微信小程序实战:从零构建一个高精度计算器

1. 为什么需要高精度计算器 在日常开发中,我们经常遇到一个头疼的问题:JavaScript的浮点数计算不准确。比如0.10.2的结果不是0.3,而是0.30000000000000004。这种精度问题在金融、科学计算等场景下会造成严重错误。 我在开发电商小程序时就踩过…...

【限时公开】某头部电力IoT厂商已量产的嵌入式大模型部署框架(含CMSIS-NN定制OP扩展包+GDB远程符号调试桩),仅开放前500名开发者下载

更多请点击: https://intelliparadigm.com 第一章:嵌入式 C 语言与轻量级大模型适配 生产环境部署 在资源受限的嵌入式设备(如 Cortex-M7、ESP32-S3 或 RISC-V MCU)上部署轻量级大模型,需突破传统 C 语言生态与神经网…...

Google TimesFM实战:零代码搞定时间序列预测(附数据集获取技巧)

Google TimesFM实战:零代码搞定时间序列预测(附数据集获取技巧) 时间序列预测一直是商业决策中的关键工具,从销售趋势分析到库存管理,再到市场需求预测,准确的时间序列预测能帮助企业提前布局,…...

【UG/NX二次开发】核心函数实战:从对话框交互到几何建模

1. UG/NX二次开发入门:从零搭建参数化对话框 UG/NX作为工业设计领域的标杆软件,其二次开发能力让工程师能够将重复性工作自动化。我第一次接触NX Open API时,面对上千个函数确实有些无从下手。后来发现,从对话框开发切入是最快上手…...

PS 抠完图怎么加外描边?超简单 3 种方法,零基础秒学会

做设计、电商配图、海报制作时,抠图只是基础步骤。给抠好的人物、产品、素材添加描边,既能强化主体轮廓、区分画面层次,还能提升整体视觉质感。但很多 PS 新手抠完图后,不知道怎么快速加描边,容易出现边缘锯齿、描边遮…...

Betaflight飞控系统实战:解决无人机飞行稳定性问题的完整方案

Betaflight飞控系统实战:解决无人机飞行稳定性问题的完整方案 【免费下载链接】betaflight Open Source Flight Controller Firmware 项目地址: https://gitcode.com/gh_mirrors/be/betaflight Betaflight作为开源无人机飞控系统的标杆,为FPV竞速…...

没有PS基础,怎么给黑白照片上色?步骤清晰一看就会

很多人家里都留存着老旧黑白照片,想要翻新上色、还原复古色彩;也有不少日常黑白素材,需要转换成彩色版本。很多零基础小白一看到 PS 众多工具就犯难,手动上色容易颜色杂乱、肤色失真、画面违和。今天就给大家分享纯新手也能看懂的…...

别再只盯着SQL注入了!熊海CMS靶场隐藏的XSS与文件包含漏洞挖掘指南

熊海CMS靶场深度审计:突破SQL注入思维定式的XSS与文件包含实战 在安全测试领域,SQL注入往往成为初学者的"舒适区",而熊海CMS靶场恰恰提供了突破这种思维定式的绝佳训练场。当我们过度聚焦于数据库层面的攻击时,可能忽略…...

联邦学习在勒索软件检测中的隐私保护应用

1. 联邦学习与勒索软件检测的隐私保护应用概述勒索软件已成为当今网络安全领域最具破坏性的威胁之一。这类恶意软件通过加密受害者文件或锁定系统访问权限,要求支付赎金才能恢复数据。根据统计,全球每年因勒索软件造成的经济损失高达数千亿美元。传统检测…...

IIC协议常见误区解析:从时序图到实际波形(附逻辑分析仪实测)

IIC协议实战避坑指南:从理论时序到真实波形的深度解析 调试IIC总线就像在跟一个性格内向的技术专家对话——协议规范看似简单明了,但实际交互中那些微妙的停顿、眼神交流和潜台词才是真正决定沟通成败的关键。本文将带您穿透理想时序图的表象&#xff0c…...

Phi-3.5-Mini-Instruct效果验证:对LLM幻觉内容主动标注‘不确定’并提供依据

Phi-3.5-Mini-Instruct效果验证:对LLM幻觉内容主动标注不确定并提供依据 1. 项目背景与核心价值 微软Phi-3.5-Mini-Instruct作为轻量级大模型的代表,在保持小体积的同时展现了出色的逻辑推理和问答能力。然而,与所有大语言模型一样&#xf…...

iOS 16+小程序防截屏录屏实战:wx.setVisualEffectOnCapture 保姆级配置与兼容性避坑

iOS 16小程序防截屏录屏实战:wx.setVisualEffectOnCapture 保姆级配置与兼容性避坑 在移动应用开发中,内容安全保护一直是开发者关注的重点。特别是对于金融、医疗、教育等涉及敏感信息的微信小程序,防止用户截屏或录屏成为保障数据安全的重要…...

如何5分钟搞定GitHub加速:新手的终极解决方案指南

如何5分钟搞定GitHub加速:新手的终极解决方案指南 【免费下载链接】Fast-GitHub 国内Github下载很慢,用上了这个插件后,下载速度嗖嗖嗖的~! 项目地址: https://gitcode.com/gh_mirrors/fa/Fast-GitHub 你是否曾因GitHub下载…...

从农历生日到公历提醒:基于sxtwl和Flask,手把手教你搭建个人农历纪念日提醒系统

打造智能农历纪念日管家:用Python和Flask实现自动提醒系统 每逢家人农历生日临近,总有人手忙脚乱翻看日历换算日期?传统节日当天才临时准备礼物?现在,用30行核心代码就能打造专属的智能提醒系统。本文将带你从零构建一…...

CentOS8部署Ansible实战:从零到配置完成的避坑指南

1. 为什么选择Ansible?CentOS8部署前的思考 第一次接触Ansible是在管理十几台服务器的时候。当时手动操作每台机器装软件、改配置,不仅效率低还容易出错。Ansible就像个智能遥控器,能同时控制所有机器执行相同操作,而且不需要在目…...

解锁AMD Ryzen全部潜力:SMUDebugTool硬件调试工具完全指南

解锁AMD Ryzen全部潜力:SMUDebugTool硬件调试工具完全指南 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https:…...

ArcGIS Pro新手必看:三招搞定遥感影像黑边,让你的地图更干净(附NoData设置技巧)

ArcGIS Pro遥感影像黑边处理实战指南:从快速修复到专业解决方案 第一次在ArcGIS Pro中加载从微图下载的谷歌地球影像时,那些突兀的黑边总让人感到困扰。这些无效数据区域不仅影响地图美观度,还会在后续分析、镶嵌处理中带来各种问题。作为GIS…...

Filelocator Pro正则搜索避坑指南:从‘翻车’案例到高效查询的3个关键步骤

Filelocator Pro正则搜索避坑指南:从‘翻车’案例到高效查询的3个关键步骤 在数据处理和文本分析领域,Filelocator Pro凭借其强大的布尔搜索和正则表达式功能,成为专业人士的首选工具之一。然而,许多用户在从基础搜索过渡到高级正…...

别再傻傻用校园网了!这5个免费文献下载神器,研究生和工程师都在偷偷用

5个科研文献免费获取方案:学生与工程师的学术资源指南 在学术研究的道路上,获取高质量的文献资料是每个研究者必须面对的基础需求。对于没有机构订阅权限的独立学者、初创团队工程师或预算有限的学生群体来说,如何绕过付费墙获取所需文献成为…...

LLM服务优化:异构硬件与模拟平台技术解析

1. LLMServingSim2.0:异构硬件与LLM服务技术的统一模拟平台在大型语言模型(LLM)推理服务领域,硬件加速器与软件策略的协同优化已成为提升服务效率的关键。然而,传统模拟器存在两大核心痛点:硬件集成缺乏标准…...

保姆级教程:在OpenWrt软路由上,用Docker和脚本两种方式搞定AdGuard Home和MosDNS v5.3.1

软路由双雄会:AdGuard Home与MosDNS v5.3.1在OpenWrt上的终极部署指南 当家庭宽带接入设备超过20台时,传统路由器的DNS处理能力往往成为网络体验的瓶颈。我曾为一个摄影工作室调试网络时发现,即便在千兆光纤环境下,设备间的网页加…...

STM32CubeMX实战:DHT11温湿度数据采集与串口打印

1. DHT11温湿度传感器基础认知 第一次接触DHT11这个蓝色小模块时,我完全没想到它会在后来的智能家居项目中扮演如此重要的角色。这个比硬币大不了多少的传感器,内部却藏着测量温湿度的精妙机制。DHT11采用电阻式感温元件和湿敏电容的组合设计&#xff0c…...

【收藏备用】2026年金三银四程序员薪资揭秘!大模型红利期,小白/程序员必看

又是一年金三银四求职旺季,程序员群体已悄然迎来新一轮职业挑战——在行业普遍降本增效的大背景下,单纯靠“搬砖”式编码早已难以立足,唯有通过技术深耕、紧跟行业风口,才能实现个人价值的跨越式跃升。这场关乎职业发展的“硬仗”…...

跨形态世界模型:机器人灵巧操作的通用动力学表示

1. 跨形态世界模型的技术框架解析在机器人灵巧操作领域,跨形态世界模型代表了一种突破性的技术路径。这项技术的核心在于建立不受具体机械结构限制的通用动力学表示,使得从人类手部动作到各类机器人手的操作策略能够无缝迁移。让我们深入剖析这个框架的构…...

收藏!2026年版实践派攻略:大模型怎么学才更容易快速上手?

在2026大模型普及落地的时代,想要零基础入门、程序员跨界转型AI赛道,实操落地永远是核心关键。脱离实践纯啃理论,只会越学越迷茫。想要高效入门大模型,硬件基础一定要提前备好,大家可以入手本地显卡,也可以…...

FPGA数据流处理小技巧:深度解读Shift Register IP核的‘额外周期’坑与可变延时实战

FPGA数据流处理实战:揭秘Shift Register IP核的延时陷阱与动态配置技巧 在图像处理流水线中,我们常常需要对像素数据进行精确的时序对齐。上周调试一个实时边缘检测系统时,发现经过移位寄存器处理后的Sobel算子计算结果总是比预期晚一个周期出…...

从Java线程状态到订单状态机:手把手教你用状态图设计清晰业务逻辑(避坑指南)

从Java线程状态到订单状态机:手把手教你用状态图设计清晰业务逻辑(避坑指南) 在构建复杂业务系统时,状态管理往往是系统稳定性的关键所在。想象一下电商平台中一个订单从创建到完成的完整生命周期,或是工单系统中一个…...

别再为故障分析头疼了!手把手教你用CWSOE模块搭建风电场分布式SOE记录系统(含NTP对时配置)

风电运维实战:基于CWSOE模块的分布式SOE系统部署全指南 引言:为什么风电场的故障分析需要专业SOE系统? 去年冬天,北方某200MW风电场遭遇了一次全场停机事故。运维团队花了整整三天时间排查故障原因,最终发现是一台箱变…...