加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Qt编译PostgreSQL数据库驱动

发布时间:2020-12-13 17:27:01 所属栏目:百科 来源:网络整理
导读:走了太多弯路了,晚上试了两个多小时,最后才在一位兄弟的帖子的帮助下搞定。 他的思路挺好的, 直接把postgresql的include目录和lib目录拷出来。 另外修改psql.pro文件时候, 注意LIBS+= './psql_lib /libpq.lib ',注意要把具体的lib文件名加上。 然后直接

走了太多弯路了,晚上试了两个多小时,最后才在一位兄弟的帖子的帮助下搞定。

他的思路挺好的, 直接把postgresql的include目录和lib目录拷出来。

另外修改psql.pro文件时候, 注意LIBS+= './psql_lib/libpq.lib',注意要把具体的lib文件名加上。

然后直接 qmake,

下一步,不知道为什么 要make debug和make release分开运行

make

然后把生成的文件拷贝到sqldrivers目录下去即可。


此文档针对windows下Qt Creator + Qt SDK用户,开发环境配置参见本人其他博文

qt由于授权许可的限制,Qt的开源版本没有提供所有数据库的驱动程序。免费下载的中只含有QSQLITE也就是SQLite的驱动程序,要想与mysql或oracle等连接需要自己编译其驱动。
由于种种问题,经历各种重装,各种失败,本人用了两天才成功用qt连接上了mysql数据库。(看网上其他教程都是分分钟搞定-_-!!)在这里也写一下自己的经历。
下边开始正文:
一.下载mysqlhttp://dev.mysql.com/downloads/目前最新版本5.5。
二.安装mysql安装时不能选择Typical型,这样会缺少库文件(include和lib文件夹)。啥都不管直接选择FUll型。
三.将mysql安装目录下的include和lib两个文件夹拷贝到qt4.7.4srcpluginssqldriversmysql下。可以自己新建一个目录如mysqllib。
四.修改mysql.pro文件,在第二行添加如下内容
INCLUDEPATH+= "./mysqllib/include"
LIBS+="./mysqllib/lib/libmysql.lib"
五.将QT的bin目录和mingw的目录都添加到环境变量的path中。
六.运行qt4.7.4 Command Prompt 输入以下命令(路径自己注意修改)
cdqt4.7.4srcpluginssqldriversmysql
qmake
mingw32-makerelease
mingw32-makedebug
执行qmake后没有返回结果,只是在mysql目录下生成了debug和release的makefile文件Makefile.Debug和Makefile.Release。
全部执行完后,将release下的libqsqlmysql4.a,qsqlmysql4.dll和debug下的libqsqlmysqld4.a,libqsqlmysqld4.dll拷贝至
QtSDKDesktopQt4.7.4mingwpluginssqldrivers
目录下
七.将mysql的库文件libmysql.dll拷贝到QtSDKDesktopQt4.7.4mingwbin目录下

接下来运行一个例子看驱动是否装好:
新建一个qt gui控制台项目SQLtest
在SQLtest.pro中加入QT+=sql
接着修改main.cpp如下

#include <QtCore/QCoreApplication>

#include <QtSql>intmain(int argc,char *argv[]){

QCoreApplication a(argc,argv);

qDebug()<< "Available drivers:";

QStringList drivers = QSqlDatabase::drivers();

foreach(QStringdriver,drivers)qDebug() << "t "<<driver;

qDebug()<< "End";

return a.exec();

}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读