Linux C/C++程序员 但行好事 莫问前程 Linux系统下 解决Qt5无法连接MySQL数据库的方法
Linux平台下解决Qt5连接mysql数据库的问题:输入sudo apt-get install libqt5sql5-mysql解决,这种方法只能解决Qt是用sudo apt-get install qt-sdk命令装的低版本的Qt5(如5.2.x)缺少MySQL驱动问题,如果你的Qt5版本为5.7.X,那么就不能用这种方法解决,请参考下面的方法。
转载地址:http://www.cnblogs.com/yongqiang/p/6121515.html
传统解决方法:
一、解决问题
本文解决在Ubuntu14.04系统下,Qt5无法连接MySQL数据库的问题(Qt5缺少MySQL驱动,Qt5缺少libqsqlmysql.so动态库,如何安装libqsqlmysql库,如何用Qt5源码编译生成libqsqlmysql库)
二、问题现象
编译运行Qt连接MySQL数据库程序的时候,控制台会报如下错误:
QSqlDatabase: QMYSQL driver not loaded
QSqlDatabase: available drivers: QSQLITE
三、问题原因
用Qt连接MySQL,Qt会去加载libqsqlmysql.so动态库,如果加载不到或者加载的库有问题,都会导致Qt提示driver not loaded。
(1)加载不到:Qt安装目录下的sqldrivers目录中没有libqsqlmysql.so文件(我的路径:/opt/Qt5.7.0/5.7/gcc_64/plugins/sqldrivers)
(2)库有问题:进入Qt的sqldrivers目录,执行“ldd libqsqlmysql.so”命令,会出现“libmysqlclient_r.so.16 => not found”等等not found提示,如下图:
四、解决方法
思路:自己手动编译mysql驱动的源码,生成libqsqlmysql.so库,然后把这个库拷贝到Qt的sqldrivers目录下
1、编译libqsqlmysql.so之前需要拿到Qt连接mysql驱动的源码,因此先去Qt官网下载Qt安装包qt-opensource-linux-x64-5.7.0.run
(1)打开网址:https://www.qt.io/,点击Download
(2)做一套选择题,一路选下去:
(也可以直接打开这个网址(可能失效):https://www.qt.io/download-open-source/,选View All Downloads)
(3)选择查看所有的下载资源(View All Downloads)
(4)选择下载的版本(我选的是Qt 5.7.0 for Linux64-bit)
2、安装Qt
(1)运行安装包(我是把Qt安装到系统根目录下的)
若想安装到系统根目录下,则执行:sudo ./qt-opensource-linux-x64-5.7.0.run
若想安装到用户根目录下,则执行:./qt-opensource-linux-x64-5.7.0.run
(2)选择安装源码组件
3、编译生成Qt连接MySql的驱动,即libqsqlmysql.so
(1)进入Qt安装目录,找到MySql驱动源码目录
参考我的目录:/opt/Qt5.7.0/5.7/Src/qtbase/src/plugins/sqldrivers/mysql
注:每个人的源码目录可能不同,找的时候参考Src,qtbase、plugins、sqldrivers、mysql目录去找就没错。
(2)执行qmake生成Makefile。
注:如果之前安装过其他Qt版本,那么可能执行的是其他版本qmake。
不妨执行“qmake -v”命令查看一下qmake的版本是否与我们刚安装的Qt的qmake一致。
最佳方案:首先找到新安装的Qt的qmake所在路径,然后找到mysql.h头文件所在路径,最后执行qmake命令生成Makefile(建议执行qmake的时候带上qmake的路径)
qmake命令:sudo /opt/Qt5.7.0/5.7/gcc_64/bin/qmake "INCLUDEPATH+=/usr/include/mysql" "LIBS+=-L/usr/lib -lmysqlclient_r" mysql.pro
执行的过程中如果报错,仔细看错误是找不到目录还是找不到库文件,按照上面的方法去找或者去安装库,在执行qmake命令就可以了。
我以我的系统为例操作一下:
(3)生成libqsqlmysql.so
执行命令:make
注意make命令输出的最后几行,指出了生成的libqsqlmysql.so位置。
4、把生成libqsqlmysql.so拷贝到sqldrivers文件夹下(我是拷贝到:/opt/Qt5.7.0/5.7/gcc_64/plugins/sqldrivers)
五、测试样例
到这里,Qt就已经可以连接MySql数据库了,拷贝这个程序去试试吧。
pro文件中添加这句话“QT += sql”,让Qt加载数据库模块
1 #include <QCoreApplication> 2 #include <QSqlDatabase> 3 #include <QSqlQuery> 4 #include <QSqlTableModel> 5 #include <QSqlError> 6 #include <QDebug> 7 8 int main(int argc, char *argv[]) 9 { 10 QCoreApplication app(argc, argv); 11 QSqlDatabase db = QSqlDatabase::addDatabase("QMYSQL"); //database driver 12 db.setHostName("localhost"); //database ip address 13 db.setUserName("username"); //database username 14 db.setPassword("password"); //database password 15 db.setDatabaseName("HC"); //database table name 16 if (true == db.open()) 17 { 18 qDebug() << "succ"; 19 } 20 else 21 { 22 qDebug() << "failed"; 23 exit(0); 24 } 25 return app.exec(); 26 }
Linux C/C++程序员 但行好事 莫问前程 Linux系统下 解决Qt5无法连接MySQL数据库的方法相关推荐
- linux mysql如何远程连接mysql数据库,Linux下远程连接MySQL数据库的方法
Linux下远程连接MySQL数据库的方法 踩坑笔记 估计搞了一个多小时才把这个远程连接搞好.一台本地电脑,一台云服务器,都是linux系统. 步骤 1.在服务器端开启远程访问 首先进入mysql数据 ...
- Linux kubuntu x64系统下解决QT5.12编辑菜单和工具栏不显示图标问题
Linux kubuntu x64系统下发现QT5.12在设计视图下编辑菜单和工具栏显示图标,但是编译运行后发现菜单和工具栏不显示图标,如下图: 我的解决办法是: 1.在QT项目中,菜单和工具栏图标一 ...
- linux 怎么登陆mysql数据库连接_Linux系统下实现远程连接MySQL数据库的方法教程
前言 最近在工作中遇到了这个需求,估计搞了一个多小时才把这个远程连接搞好.一台本地电脑,一台云服务器,都是linux系统.下面来看看详细的介绍: 步骤 1.在服务器端开启远程访问 首先进入mysql数 ...
- linux(ARM架构)下的mysql安装、QT连接mysql数据库(完整版)
一.安装MYSQL之前要先换源 二.安装MYSQL 1.安装 2.安装完成 3.安装后无法登陆 3.1 原因 3.2 登陆后切换database 3.3 修改密码(注意这里账号和密码是双引号) 3.4 ...
- mye连接mysql数据库_MySQL_如何在Java程序中访问mysql数据库中的数据并进行简单的操作,在上篇文章给大家介绍了Myeclip - phpStudy...
如何在Java程序中访问mysql数据库中的数据并进行简单的操作 在上篇文章给大家介绍了Myeclipse连接mysql数据库的方法,通过本文给大家介绍如何在Java程序中访问mysql数据库中的数据 ...
- 完了!Windows弱爆了!Linux才是程序员的首选!程序员:好用!
最近有很多程序员在CSDN博客发帖讨论:用Windows还是Linux? 关于这个问题,其实答案很简单:做开发首选Linux. 如果一个程序员从来没有在Linux上开发过程序, 一直在Windows上 ...
- 数学149的女学霸,直言想当程序员!女生当程序员到底行不行?
最近一段时间,全国多个省市的高考分数线录像出炉,各地又多了一堆学霸秀分数了,他们的专业选择也成为网友们津津乐道的闲谈.这两天有报道称,四川成都一学校的女学霸出名了,在采访中她透露自己高考分数达到了69 ...
- C++程序员这行能干一辈子吗?
有人说,程序员这一行就是吃青春饭,不能干一辈子,因为程序员面对的是一份高强度的工作,同时面临着技术的快速迭代,对于身体素质.学习能力等都有很高的要求,所以很多人都面临入行即焦虑的现象. 那事实真的如此 ...
- 来聊聊 | 在中国,程序员这行真能干一辈子吗?
前段时间,64岁的程序员Guido van Rossum发推表示,退休生活太无聊,决定入职微软,将开源进行到底. Guido因是Python程序设计语言的作者而为人们熟知,因此他也被人称作" ...
- 用c语言400行代码小游戏,程序员400行代码制作翻牌游戏解决无聊时间
原标题:程序员400行代码制作翻牌游戏解决无聊时间 上班感觉累,很想放假,但是放假在家又感觉非常无聊,总是不知道干什么,又感觉还不如上班呢,反正无聊不如练练写小游戏吧,即练习了代码,做完后还能接着玩, ...
最新文章
- 人工神经网络-2020-第十四周-人工神经网络硬件实现-备课
- java发送短信模板_java发送短信
- 还不懂Redis?看完这个故事就明白了!
- class h5 点击后样式变化_【php】JQuery怎么实现页面刷新后保留鼠标点击addclass的样式?...
- 智能城市技术能够更好地改善日常生活
- js常用内建对象之:Date
- 使用CDN时注意的问题
- JAVA游戏——潜艇大战
- Nachos操作系统-文件系统添加多级目录
- 三款免费好用的Gif录屏神器
- 基于XP系统的asp.net运行环境的安装与配置
- DIY个性家装心得家用电动工具选择
- php+aira2+ffmpeg下载m3u8文件并保存成mp4
- python开发者是谁_Python 太蹩脚了?开发者总结了 8 大缘故
- 「 Gazebo仿真 」地图创建、多模型显示、基本指令
- BGP综合认知及配置
- python多个文件夹合并成一个文件夹
- ADAMS 常用快捷键速记
- 再度联手中国联通,开启第二个五年战略合作!
- 《数据库系统原理》实验6:视图管理
热门文章
- Windows安装MySql
- Flow-Guided-Feature-Aggregation-的安装配置,demo运行,以及采用少量ILSVRC2015 VID数据集在其中训练
- matlab把图像白色部分变透明,怎么将PPT中的白底图片,白色部分变透明
- django @csrf_exempt
- 普林斯顿大学计算机科学排名,普林斯顿大学研究生计算机系统专业排名
- 重装系统Win7步骤和详细教程
- Cesium场景导出为图片功能
- Self-Attention with Relative Position Representations(2018)
- Python 查看微信撤回消息
- 内涵社区APP,一款集内涵段子,百思不得其姐,煎蛋于一身的搞笑社区