QT连接mysql、oracle数据库可执行程序的移植性问题
2013-10-12 16:38
429 查看
在项目开发的过程中VS2010用到了QT连接数据库的实现功能,但在移植到其他机器上的时候出现了drivers not load的问题,之后在网上找到了相关的答案如网址http://blog.csdn.net/NRC_DouNingBo/article/details/5701586,但是在执行的时候发现有一点偏差。我所写的语句是这样的
QApplication app(argc,argv);
QString strLibPath(QDir::toNativeSeparators(QApplication::applicationDirPath())+QDir::separator()+"plugins");
app.addLibraryPath(strLibPath);
还需要一些相关头文件<QtCore/QApplication>等,这些自己应该可以判定的,就不详细赘述。
然后需要在附加依赖项中添加QT5Widgetsd.lib这个静态库,然后可以用depency walk查看exe文件所需要的动态库,全都拷贝到exe文件当前目录下,通常是这么几个:
icudt51.dll,icuin51.dll,icuuc51.dll,Qt5Guid.dll,Qt5Widgetsd.dll,libmysql.dll,Qt5Sqld.dll。然后在exe当前目录下新建个名叫sqldrivers的文件夹,必须是这个
名字,在里面放你所要用到的数据库的动态库驱动如Qsqlmysqld.dll等;再新建个platforms的文件夹,也必须是这个名字,在里面放QWindowsd.dll这个动态库,然后
点击exe文件,在其他机器上就可以完美运行啦。
PS:我所移植的程序机器上有vc2010和.net 4.0环境,如果按照上述方法执行不了,可以试下安装这些相关环境。
QApplication app(argc,argv);
QString strLibPath(QDir::toNativeSeparators(QApplication::applicationDirPath())+QDir::separator()+"plugins");
app.addLibraryPath(strLibPath);
还需要一些相关头文件<QtCore/QApplication>等,这些自己应该可以判定的,就不详细赘述。
然后需要在附加依赖项中添加QT5Widgetsd.lib这个静态库,然后可以用depency walk查看exe文件所需要的动态库,全都拷贝到exe文件当前目录下,通常是这么几个:
icudt51.dll,icuin51.dll,icuuc51.dll,Qt5Guid.dll,Qt5Widgetsd.dll,libmysql.dll,Qt5Sqld.dll。然后在exe当前目录下新建个名叫sqldrivers的文件夹,必须是这个
名字,在里面放你所要用到的数据库的动态库驱动如Qsqlmysqld.dll等;再新建个platforms的文件夹,也必须是这个名字,在里面放QWindowsd.dll这个动态库,然后
点击exe文件,在其他机器上就可以完美运行啦。
PS:我所移植的程序机器上有vc2010和.net 4.0环境,如果按照上述方法执行不了,可以试下安装这些相关环境。
相关文章推荐
- Qt_阴影效果
- QTP笔记——学会用With...End With
- Qt动画----窗体渐进开启
- QTP笔记——Object Spy获取对象模式
- QTP笔记——选取“垂直柱”
- qt出现警告 Unescaped backslashes are deprecated!解决办法
- qtextend4.4.3 在nuc900平台下编译问题及解决办法
- Qt容器类
- QT命令
- 嵌入式Qt开发环境搭建及移植到开发板----Qt学习笔记
- VS2005下QT学习笔记-导入.qrc资源文件
- QT总结第3篇:如何在QT中添加.lib,.dll还有.h文件
- QT小知识
- Qt多线程相关<一>
- QT总结第2篇:在QT中创建一个线程
- QT总结第1篇:创建一个QT工程
- QTableView和QTableWidget翻页功能实现
- 搭建qt的交叉编译环境
- QTableView基本用法讲解,Qt表格控件的使用方法
- 编写Qt Designer自定义控件(二)——编写自定义控件界面