Ubuntu,QT5连接MySQL
2016-01-15 12:27
453 查看
用QT连接MySQL需要共享库 libqsqlmysql.so的驱动,路径在plugin/sqldrivers目录下,乍看已经可用了,其实不然。
用ldd命令分析一下,libmysqlclient_r.so.* => not found ,后明显libmysqlclient_r.so.* 缺少另一个共享库,他们是依赖关系,解决了这个问题QT才能真的连接到MySQL数据库。而我的/usr/lib64/下的共享库版本比较高是 libmysqlclient.so.18,想到了一个比较投机的想法ln创建符号链接,然而这并没有什么卵用。
PS:ldd:linux下分析打印可执行档依赖的共享库文件。
让我哭笑不得是QT5.5是我从官网下载的,居然依赖的是低版本,你们编译的时候能不能不偷懒啊,估计他们直接从低版本拷贝的libqsqlmysql.so,没办法了吗?显然不是,打开qt官网下载源码,自己编译。下载过程略过,非常好找 http://download.qt.io/official_releases/qt/5.5/5.5.1/submodules/ (暂时没有qt5.5的源码),找到qtbase那个大概60M。MySql驱动的路径为qtbase/src/plugins/sqldrivers/mysql/。
qmake "INCLUDEPATH+=/usr/include" "LIBS+=-L/usr/lib -lmysqlclient_r" mysql.pro
(include为头文件“mysql.h”的位置,可用“ sudo find -name "mysql.h" ”找找看,lib为共享库到位置)
make
sudo make install
PS:如果没有没找到“mysql.h”文件,需要安装“mysql-libmysqlclient-dev”
sudo apt-get install libmysqlclient-dev
在QT的帮助手册中输入“SQL Database Drivers”,可查看其他数据库到连接方式
这样就能连接MySQL数据库了。
参考资料:
CentOS7 (64位) 下QT5.5 连接MySQL数据库(driver not loaded)
fatal error: mysql/mysql.h: No such file or directory 解决方法
用ldd命令分析一下,libmysqlclient_r.so.* => not found ,后明显libmysqlclient_r.so.* 缺少另一个共享库,他们是依赖关系,解决了这个问题QT才能真的连接到MySQL数据库。而我的/usr/lib64/下的共享库版本比较高是 libmysqlclient.so.18,想到了一个比较投机的想法ln创建符号链接,然而这并没有什么卵用。
PS:ldd:linux下分析打印可执行档依赖的共享库文件。
让我哭笑不得是QT5.5是我从官网下载的,居然依赖的是低版本,你们编译的时候能不能不偷懒啊,估计他们直接从低版本拷贝的libqsqlmysql.so,没办法了吗?显然不是,打开qt官网下载源码,自己编译。下载过程略过,非常好找 http://download.qt.io/official_releases/qt/5.5/5.5.1/submodules/ (暂时没有qt5.5的源码),找到qtbase那个大概60M。MySql驱动的路径为qtbase/src/plugins/sqldrivers/mysql/。
qmake "INCLUDEPATH+=/usr/include" "LIBS+=-L/usr/lib -lmysqlclient_r" mysql.pro
(include为头文件“mysql.h”的位置,可用“ sudo find -name "mysql.h" ”找找看,lib为共享库到位置)
make
sudo make install
PS:如果没有没找到“mysql.h”文件,需要安装“mysql-libmysqlclient-dev”
sudo apt-get install libmysqlclient-dev
在QT的帮助手册中输入“SQL Database Drivers”,可查看其他数据库到连接方式
这样就能连接MySQL数据库了。
参考资料:
CentOS7 (64位) 下QT5.5 连接MySQL数据库(driver not loaded)
fatal error: mysql/mysql.h: No such file or directory 解决方法
相关文章推荐
- Qt的.pro工程文件语法学习
- QT子线程与主线程的信号槽通信
- osg3.4.0+Qt5.5.0 vs2013 64位编译成功
- Qt中项目一栏配置说明
- Qt5链接Mysql的驱动命令
- QT 常用设置
- qt 信号槽(connect)失效,【多线程使用信号槽】
- Node.js 搭建mqttServer 及 mqttClient
- QT子窗体占用系统资源的释放问题 .
- QT之QSetting类
- qtcreator cannot find -lts
- QTP WebBrowser &Page控件
- 自学QT之UDP发送数据
- Qt(安装及首次体验)
- QT错误处理汇总
- Lepus经历收获杂谈(二)——QT
- QSettings读写注册表、配置文件
- QT CREATOR 编辑器配色
- Qt编译增加FLAG
- qtooltip源码学习