当前位置:  数据库>oracle

Mac系统下Qt 4.8编译连接数据库(Oracle,MySql)

    来源: 互联网  发布时间:2017-04-23

    本文导语: 在Mac下成功编译了MySql和Oracle的数据库插件驱动,但遗憾的是在程序中无论如何也加载不了这两个驱动,也无法连接数据库。在环境变量中设置QT_DEBUG_PLUGINS=1, 再启动程序后Qt会报告一些加载插件的调试信息,从中可以看出是插件...

Mac下成功编译MySqlOracle数据库插件驱动,但遗憾的是在程序中无论如何也加载不了这两个驱动,也无法Oracle iis7站长之家数据库。在环境变量中设置QT_DEBUG_PLUGINS=1, 再启动程序后Qt会报告一些加载插件的调试信息,从中可以看出是插件不兼容引起的,也就是文档中所说的Build Key的问题,在文档中有提到可能需要清除插件缓存Plugin cache),应该是在一个QSettings定义的文件中,但我没找到。无奈下将QtSDK删除重新安装一遍,又从头开始,最后终于成功。下面记录详细的过程,供日后参考。

1. 首先安装QtSDK 1.2, 安装在 ~/QtSDK目录下,安装的时候要选择安装4.8.0的源代码,否则后面无法编译plugin;

2. 下载mysql和oracle的数据库连接动态库;可从官网下载,注意选择与你的系统合适的版本,我这里是max osx 10.7.3 64bit;mysql下载的是mysql-connector-c-6.0.2-osx10.5-x86-64bit.tar.gz, oracle下需要的是instantclient basic包和instantclient sdk包。

3. 将下载的数据库文档解压缩到本地目录下,记录下文件目录;MySql解压在~/bin/mysql目录下,下面会有includelib子目录;oracle的两个包解压到~/bin/oracle目录下,目录下有库文件和sdk目录;

4.准备工作完了后,开始编译生成Qt库;首先执行命令(后面3行是一个命令,因太长了分行显示)

  • cd ~/QtSDK/QtSources/4.8.0  
  • ./configure -opensource -prefix /Users/lutx/QtSDK/Desktop/Qt/4.8.0/gcc -plugin-sql-mysql -plugin-sql-oci  
  •  -plugin-sql-odbc -plugin-sql-sqllite -I/Users/lutx/bin/mysql/include -I/Users/lutx/bin/oracle/sdk/include  
  •  -L/Users/lutx/bin/mysql/lib -L/Users/lutx/bin/oracle
  • 上面的命令中,prefix是定义编译后的安装目录,默认是安装到/usr/local/Trolltech/Qt-4.8.0目录下,我这里给定义安装到 QtSDK的目录下,这样可以避免后面在QtCreator中配置版本,或者利用install_name_tools修改动态库名称等操作。经过一段 时间(几分钟)等待后,生成了整个源目录下的makefile文件。系统应该显示

  • Qt is now configured for building. Just run 'make'.  
  • Once everything is built, you must run 'make install'.  
  • Qt will be installed into /Users/[xxxx]/QtSDK/Desktop/Qt/4.8.0/gcc  
  •   
  • To reconfigure, run 'make confclean' and 'configure'.  
  • 上面的[xxxx]应该是你的系统登录用户名,下同。

    5.下面开始编译过程,应该很简单,直接在刚才的目录下继续执行make命令即可,www.linuxidc.com 但是我这里在编译到QtWebkit这个库的时候会有错误,因此后面将跳过这个库继续编译后面的库。出现的错误是:

  • fileapi/FileReaderLoader.cppIn member function ‘void WebCore::FileReaderLoader::convertToDataURL()’:  
  • fileapi/FileReaderLoader.cpp:307: error: ‘base64Encode’ was not declared in this scope  
  • make[3]: *** [.obj/debug-static/filereaderloader.o] error 1  
  • make[2]: *** [debug-all] Error 2  
  • make[1]: *** [sub-WebCore-make_default-ordered] Error 2  
  • 这里也不知道是么原因,没搞明白。

    5.通过Makefile文件知道,在Webkit后面还有scripttools,plugins(这个是主要目的), 后面用命令逐个编译每个库。

  • cd src/scripttools;make;cd ../plugins;make;cd ../imports;make;cd ../tools;make;cd ../translations;make;cd ../..  
  • make install  
  • 因为不是必需的,最后没有编译examples和demos两个目录。

    如此编译已经成功,另外在程序运行时需要将mysql的lib目录和oracle的lib目录加到环境变量DYLD_LIBRARY_PATH中,否则还是无法加载数据库插件驱动。


        
     
     
     
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • java命名空间javax.crypto类mac的类成员方法: mac定义及介绍
  • Mac的搜索框 qsb-mac
  • java命名空间javax.crypto类mac的类成员方法: getmaclength定义及介绍
  • 请问怎样编程获得本机的MAC地址?还有能不能设置本机MAC地址?
  • java命名空间javax.crypto类mac的类成员方法: getprovider定义及介绍
  • ifconfig -a显示的mac地址全是00,而在windows下能得到正确的MAC。什么原因?
  • java命名空间javax.crypto类mac的类成员方法: reset定义及介绍
  • php获取服务器端mac和客户端mac的地址支持WIN/LINUX
  • java命名空间javax.crypto类mac的类成员方法: getinstance定义及介绍
  • linux tc怎么对 目的MAC ,源MAC,目的IP, 源 IP,目的 port ,源 port配置带宽限制规则?谢谢
  • java命名空间javax.crypto类mac的类成员方法: dofinal定义及介绍
  • 如何更改HP9000小型机的mac地址
  • java命名空间javax.crypto类mac的类成员方法: init定义及介绍
  • 在一台SUN上用ifconfig看到mac地址是0,不太可能吧
  • java命名空间javax.crypto类mac的类成员方法: update定义及介绍
  • 改完mac地址仍然上不了网
  • java命名空间javax.crypto类mac的类成员方法: clone定义及介绍
  • 怎样修改linux下网卡的MAC地址?
  • linux/Centos下查看和修改网卡Mac地址(ifconfig命令)
  • js mac地址 正则表达式
  • Mac's CMS


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3