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数据库的方法相关推荐

  1. linux mysql如何远程连接mysql数据库,Linux下远程连接MySQL数据库的方法

    Linux下远程连接MySQL数据库的方法 踩坑笔记 估计搞了一个多小时才把这个远程连接搞好.一台本地电脑,一台云服务器,都是linux系统. 步骤 1.在服务器端开启远程访问 首先进入mysql数据 ...

  2. Linux kubuntu x64系统下解决QT5.12编辑菜单和工具栏不显示图标问题

    Linux kubuntu x64系统下发现QT5.12在设计视图下编辑菜单和工具栏显示图标,但是编译运行后发现菜单和工具栏不显示图标,如下图: 我的解决办法是: 1.在QT项目中,菜单和工具栏图标一 ...

  3. linux 怎么登陆mysql数据库连接_Linux系统下实现远程连接MySQL数据库的方法教程

    前言 最近在工作中遇到了这个需求,估计搞了一个多小时才把这个远程连接搞好.一台本地电脑,一台云服务器,都是linux系统.下面来看看详细的介绍: 步骤 1.在服务器端开启远程访问 首先进入mysql数 ...

  4. linux(ARM架构)下的mysql安装、QT连接mysql数据库(完整版)

    一.安装MYSQL之前要先换源 二.安装MYSQL 1.安装 2.安装完成 3.安装后无法登陆 3.1 原因 3.2 登陆后切换database 3.3 修改密码(注意这里账号和密码是双引号) 3.4 ...

  5. mye连接mysql数据库_MySQL_如何在Java程序中访问mysql数据库中的数据并进行简单的操作,在上篇文章给大家介绍了Myeclip - phpStudy...

    如何在Java程序中访问mysql数据库中的数据并进行简单的操作 在上篇文章给大家介绍了Myeclipse连接mysql数据库的方法,通过本文给大家介绍如何在Java程序中访问mysql数据库中的数据 ...

  6. 完了!Windows弱爆了!Linux才是程序员的首选!程序员:好用!

    最近有很多程序员在CSDN博客发帖讨论:用Windows还是Linux? 关于这个问题,其实答案很简单:做开发首选Linux. 如果一个程序员从来没有在Linux上开发过程序, 一直在Windows上 ...

  7. 数学149的女学霸,直言想当程序员!女生当程序员到底行不行?

    最近一段时间,全国多个省市的高考分数线录像出炉,各地又多了一堆学霸秀分数了,他们的专业选择也成为网友们津津乐道的闲谈.这两天有报道称,四川成都一学校的女学霸出名了,在采访中她透露自己高考分数达到了69 ...

  8. C++程序员这行能干一辈子吗?

    有人说,程序员这一行就是吃青春饭,不能干一辈子,因为程序员面对的是一份高强度的工作,同时面临着技术的快速迭代,对于身体素质.学习能力等都有很高的要求,所以很多人都面临入行即焦虑的现象. 那事实真的如此 ...

  9. 来聊聊 | 在中国,程序员这行真能干一辈子吗?

    前段时间,64岁的程序员Guido van Rossum发推表示,退休生活太无聊,决定入职微软,将开源进行到底. Guido因是Python程序设计语言的作者而为人们熟知,因此他也被人称作" ...

  10. 用c语言400行代码小游戏,程序员400行代码制作翻牌游戏解决无聊时间

    原标题:程序员400行代码制作翻牌游戏解决无聊时间 上班感觉累,很想放假,但是放假在家又感觉非常无聊,总是不知道干什么,又感觉还不如上班呢,反正无聊不如练练写小游戏吧,即练习了代码,做完后还能接着玩, ...

最新文章

  1. 人工神经网络-2020-第十四周-人工神经网络硬件实现-备课
  2. java发送短信模板_java发送短信
  3. 还不懂Redis?看完这个故事就明白了!
  4. class h5 点击后样式变化_【php】JQuery怎么实现页面刷新后保留鼠标点击addclass的样式?...
  5. 智能城市技术能够更好地改善日常生活
  6. js常用内建对象之:Date
  7. 使用CDN时注意的问题
  8. JAVA游戏——潜艇大战
  9. Nachos操作系统-文件系统添加多级目录
  10. 三款免费好用的Gif录屏神器
  11. 基于XP系统的asp.net运行环境的安装与配置
  12. DIY个性家装心得家用电动工具选择
  13. php+aira2+ffmpeg下载m3u8文件并保存成mp4
  14. python开发者是谁_Python 太蹩脚了?开发者总结了 8 大缘故
  15. 「 Gazebo仿真 」地图创建、多模型显示、基本指令
  16. BGP综合认知及配置
  17. python多个文件夹合并成一个文件夹
  18. ADAMS 常用快捷键速记
  19. 再度联手中国联通,开启第二个五年战略合作!
  20. 《数据库系统原理》实验6:视图管理

热门文章

  1. Windows安装MySql
  2. Flow-Guided-Feature-Aggregation-的安装配置,demo运行,以及采用少量ILSVRC2015 VID数据集在其中训练
  3. matlab把图像白色部分变透明,怎么将PPT中的白底图片,白色部分变透明
  4. django @csrf_exempt
  5. 普林斯顿大学计算机科学排名,普林斯顿大学研究生计算机系统专业排名
  6. 重装系统Win7步骤和详细教程
  7. Cesium场景导出为图片功能
  8. Self-Attention with Relative Position Representations(2018)
  9. Python 查看微信撤回消息
  10. 内涵社区APP,一款集内涵段子,百思不得其姐,煎蛋于一身的搞笑社区