Qt编译qsqlmysql.dll插件

感想

由于项目需要在qt环境中使用mySQL数据库,而qt4又没有直接提供qsqlmysql插件,因而只能自己编译。中间走了很多弯路,在此总结一下。

工具

  • Qt4.8.6X64_msvc2010
  • MySQL C链接库
  • MySQLServer

步骤

  • 1.如果没有Qt4.8.6X64_msvc2010 ,则需要自己下载qt ,然后编译64位的在visual studio中使用的版本。编译过程参考其他文献。
  • 2 下载 MySQL C链接库。 http://dev.mysql.com/downloads/connector/
    这里写图片描述
    我下载的是mysql-connector-c-6.1.6-winx64.msi
    把c的链接库解压到c:\mysql目录下。(放到其他目录下也可以,但是路径中不能有空格)
  • 3 找到qt4.8.6X64_msvc2010的目录。打开src\plugins\sqldrivers\mysql,我的目录是:
    C:\Qt\qt-4.8.6-x64-msvc2010\qt-4.8.6-x64-msvc2010\src\plugins\sqldrivers\mysql
    把刚刚解压的c:\mysql\lib下的libmysql.dll 和libmysql.lib复制到此目录下
    这里写图片描述
你遇到的问题是在使用Qt连接MySQL数据库时,出现了"undefined reference to `mysql_character_set_name@4'"的错误。这个错误通常是由于编译器没有找到MySQL的库文件所致。 解决这个问题的方法如下所示: 1. 首先,确保你已经正确安装了MySQL数据库,并且在你的系统中能够正常运行。 2. 检查你的Qt安装目录下的Mysql文件夹中的pri文件是否存在。这个文件通常位于类似"D:\Qt\5.14.2\Src\qtbase\src\plugins\sqldrivers\mysql"的路径下。如果该文件不存在,请确认你的Qt安装包中是否包含了MySQL插件源代码。 3. 如果存在pri文件,请双击打开它并进入Qt界面。检查该文件是否可以直接编译,如果不能,请确认是否缺少了必要的依赖库。 4. 将qsqlmysql.dll文件复制到你的Qt安装目录下的"plugins\sqldrivers"文件夹中。例如,对于你的Qt安装目录"D:\Qt\5.14.2\mingw73_64"和编译器目录"bin",复制的路径应为"D:\Qt\5.14.2\mingw73_64\plugins\sqldrivers"。 5. 将MySQL安装目录下的lib文件夹中的libmysql.dll文件复制到你的Qt安装目录下的"bin"文件夹中。这样可以确保编译器能够找到MySQL的依赖库。 6. 然后,重新运行和调试程序。你可以使用以下代码来测试数据库连接是否成功: ```cpp qDebug() << "available drivers:"; QStringList drivers = QSqlDatabase::drivers(); foreach(QString driver, drivers) qDebug() << driver; QSqlDatabase database = QSqlDatabase::addDatabase("QMYSQL"); database.setHostName("127.0.0.1"); //设置主机地址 database.setPort(3306); //设置端口,默认3306 database.setDatabaseName("**"); //设置数据库名称 database.setUserName("root"); //对应数据库的用户名 database.setPassword("****");//对应数据库的密码 if(!database.open()) qDebug() << database.lastError().text(); else qDebug() << "success"; ``` 请确保将代码中的主机地址、数据库名称、用户名和密码替换为正确的值。 希望以上步骤能够解决你遇到的问题。如果问题仍然存在,请提供更多的错误信息和背景,以便我们能够更好地帮助你。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [qt-5.14.2与Mysql的连接问题汇总](https://blog.csdn.net/Max_one/article/details/118788465)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值