昨天在Mac下成功编译了MySql和Oracle的数据库插件驱动,但遗憾的是在程序中无论如何也加载不了这两个驱动,也无法连接数据库。在环境变量中设置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目录下,下面会有include和lib子目录;oracle的两个包解压到~/bin/oracle目录下,目录下有库文件和sdk目录;