CentOS7 (64位) 下QT5.5 连接MySQL数据库(driver not loaded)
用qt连接MySQL需要共享库 libqsqlmysql.so的驱动,路径在plugin/sqldrivers目录下,乍看已经可用了,其实不然。
用ldd命令分析一下,libmysqlclient_r.so.16 => not found ,后明显libmysqlclient_r.so.16 缺少另一个共享库,他们是依赖关系,解决了这个问题qt才能真的连接到mysql数据库。而我的/usr/lib64/下的共享库版本比较高是libmysqlclient.so.18,想到了一个比较投机的想法ln创建符号链接,然而这并没有什么卵用。
让我哭笑不得是QT5.5是我从官网下载的,居然依赖的是低版本,你们编译的时候能不能不偷懒啊,估计他们直接从低版本拷贝的libqsqlmysql.so,没办法了吗?显然不是,打开qt官网下载源码,自己编译。下载过程略过,非常好找 http://download.qt.io/official_releases/qt/5.4/5.4.2/submodules/ (暂时没有qt5.5的源码),找到qtbase那个大概60M。MySql驱动的路径为qtbase/src/plugins/sqldrivers/mysql/。
- qmake
- make
然而这还没有完,make的过程中又找不到动态库了:
/usr/bin/ld: cannot find -lz
/usr/bin/ld: cannot find -lssl
/usr/bin/ld: cannot find -lcrypto
第一个是没有安装zlib-devel,直接yum install zlib-devel搞定。
第二第三项找不到是没有道理的,解决的方法:/usr/lib64/中创建符号链接
ln -s libssl.so.1.0.1e libssl.so ln -s libcrypto.so.1.0.1e libcrypto.so
再次make,成功。当然这还没有完,用新的libqsqlmysql.so去替换旧的,这就全部完成了。
再次查看:
[sqldrivers]ldd libqsqlmysql.so
linux-vdso.so. => (0x00007fff2d5fe000)
libmysqlclient.so. => /usr/lib64/mysql/libmysqlclient.so. (0x00007feb4ea24000)
libz.so. => /lib64/libz.so. (0x00007feb4e80d000)
libcrypt.so. => /lib64/libcrypt.so. (0x00007feb4e5d6000)
libnsl.so. => /lib64/libnsl.so. (0x00007feb4e3bd000)
libssl.so. => /lib64/libssl.so. (0x00007feb4e150000)
libcrypto.so. => /lib64/libcrypto.so. (0x00007feb4dd6b000)
libQt5Sql.so. => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libQt5Sql.so. (0x00007feb4db2b000)
libQt5Core.so. => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libQt5Core.so. (0x00007feb4d3e3000)
libpthread.so. => /lib64/libpthread.so. (0x00007feb4d1c7000)
libstdc++.so. => /lib64/libstdc++.so. (0x00007feb4cec0000)
libm.so. => /lib64/libm.so. (0x00007feb4cbbd000)
libgcc_s.so. => /lib64/libgcc_s.so. (0x00007feb4c9a7000)
libc.so. => /lib64/libc.so. (0x00007feb4c5e6000)
libdl.so. => /lib64/libdl.so. (0x00007feb4c3e1000)
libfreebl3.so => /lib64/libfreebl3.so (0x00007feb4c164000)
libgssapi_krb5.so. => /lib64/libgssapi_krb5.so. (0x00007feb4bf1a000)
libkrb5.so. => /lib64/libkrb5.so. (0x00007feb4bc39000)
libcom_err.so. => /lib64/libcom_err.so. (0x00007feb4ba35000)
libk5crypto.so. => /lib64/libk5crypto.so. (0x00007feb4b800000)
libicui18n.so. => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libicui18n.so. (0x00007feb4b391000)
libicuuc.so. => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libicuuc.so. (0x00007feb4afe3000)
libicudata.so. => /home/eric/Qt5.5.0/5.5/gcc_64/lib/libicudata.so. (0x00007feb495b9000)
libgthread-2.0.so. => /lib64/libgthread-2.0.so. (0x00007feb493b6000)
librt.so. => /lib64/librt.so. (0x00007feb491ae000)
libglib-2.0.so. => /lib64/libglib-2.0.so. (0x00007feb48e85000)
/lib64/ld-linux-x86-.so. (0x00007feb4f221000)
libkrb5support.so. => /lib64/libkrb5support.so. (0x00007feb48c76000)
libkeyutils.so. => /lib64/libkeyutils.so. (0x00007feb48a72000)
libresolv.so. => /lib64/libresolv.so. (0x00007feb48858000)
libselinux.so. => /lib64/libselinux.so. (0x00007feb48632000)
libpcre.so. => /lib64/libpcre.so. (0x00007feb483d1000)
liblzma.so. => /lib64/liblzma.so. (0x00007feb481ab000)
CentOS7 (64位) 下QT5.5 连接MySQL数据库(driver not loaded)的更多相关文章
- Linux系统下 解决Qt5无法连接MySQL数据库的方法
Linux平台下解决Qt5连接mysql数据库的问题:输入sudo apt-get install libqt5sql5-mysql解决,这种方法只能解决Qt是用sudo apt-get instal ...
- Win7 64位安装VS2013无法连接远程数据库
win7 64位安装vs2013后连接远程数据库出现下面的问题:A first chance exception of type 'System.AccessViolationException' o ...
- CentOS7 64位下MySQL安装与配置(YUM)
安装环境:腾讯云CentOS7 64位安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo/yum ...
- 超详细的CentOS7 64位下MySQL5.7安装与配置(YUM)【转发+新创】
安装环境:CentOS7 64位 MINI版,安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo ...
- CentOS7 64位下MySQL5.7安装与配置(YUM)转
安装环境:CentOS7 64位 MINI版,安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo ...
- CentOS7 64位下MySQL5.7安装与配置
安装环境:CentOS7 64位 MINI版,安装MySQL5.7 1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo ...
- Windows下C/C++连接mysql数据库的方法
步骤 安装MySQL数据库 项目属性页->C/C++->常规->附加包含目录:xxx\mysql Server 5.6\include 项目属性页->链接器->常规-&g ...
- CentOS7 64位下MySQL区分大小写
在使用centos系统时,安装完MySQL数据库,创建完表之后,发现查询表操作时,是区分大小写的, 说以说在创建表之前,需要查看一下数据库是否区分大小写: 查看办法: lower_case_table ...
- CentOS7 64位下MySQL5.7安装与配置(YUM)
1.配置YUM源 在MySQL官网中下载YUM源rpm安装包:http://dev.mysql.com/downloads/repo/yum/ # 下载mysql源安装包 shell> wget ...
随机推荐
- WPF实现炫酷Loading控件
Win8系统的Loading效果还是很不错的,网上也有人用CSS3等技术实现,研究了一下,并打算用WPF自定义一个Loading控件实现类似的效果,并可以让用户对Loading的颗粒(Particle ...
- 用JSON.parse和eval出现的问题
json格式非常受欢迎,而解析json的方式通常用JSON.parse()但是eval()方法也可以解析,这两者之间有什么区别呢? JSON.parse()之可以解析json格式的数据,并且会对要解析 ...
- EWS API 2.0读取日历信息-读取内容注意事项
采用模拟账号的方式读取日历信息,注意下日历的内容读取(Body)读取.代码如下:(采用 EWS API 2.0版本) 1.读取内容前必须设置如下属性:否则会提示:You must load or as ...
- go语言和资料
C/C++编程相关的复杂性,特别是大一点的工程的维护,如果人员较多,规范等都是较大的负担,最近正在关注go这么语言, 准备对于并发和系统级的开发引入. Go官网 http://golang.org h ...
- 看代码学知识之(2) ListView无数据时显示其他View
看代码学知识之(2) ListView无数据时显示其他View 今天看的一块布局是这样的: <!-- The frame layout is here since we will be show ...
- Ubuntu 安装Samba服务器
1.安装 sudo apt-get update sudo apt-get install samba (如果出现库依赖问题可用命令sudo apt-get install samba libwbcl ...
- 【Android】不依赖焦点和选中的TextView跑马灯【2】
前言 之前有写一篇TextView跑马灯的效果,后来实际项目中有发现新的问题,比如还是无法自动跑,文本超过了显示区域就截取的问题,今天换了一种思路来实现,更简单更好用. 声明 欢迎转载,但请保留文章原 ...
- (视频)《快速创建网站》 4.1 为啥造软件不同于造汽车,为啥是软件就一定会有Bug - 构建开发运维一体化(DevOps)
本文是<快速创建网站>系列的第9篇,如果你还没有看过之前的内容,建议你点击以下目录中的章节先阅读其他内容再回到本文. 访问本系列目录,请点击:http://devopshub.cn/tag ...
- Android简化xml sax解析
dom解析占用内存大(我这边需要解析各种各样的kml文件,有时4-5M的kml文件使用dom解析很多手机就内存溢出了),也需要引入第三方库,所以使用相对于节省内存很多.不需引入其他库的sax解析就是很 ...
- centos7 添加图形界面的功能
一般安装centos最小版的时候默认没有图形界面 需要自己安装 sudo yum groupinstall "GNOME Desktop" "Graphical Adm ...