今天編譯在Mac下編譯了Oracle的SQL驅動外掛程式,這裡記錄編譯過程供參考。
先介紹一下編譯環境:Mac OS X 10.7.3, 安裝Qt SDK 1.2 for Mac,XCode 4.2.1。
1. 首先是到Oracle的網站上下載相關的庫和開發包,按照Qt文檔中的說明(How to Build the OCI Plugin on Unix and Mac OS X),需要下載"Instant Client Package - Basic"和"Instant Client Package - SDK"兩個包,可以從這裡找到要下載的內容。
2. 把下載的zip檔案解壓到同一個目錄下,如Oracle10gClient;
3. 編譯。在qt的文檔中有兩種方法,一個是利用configure產生makefile在執行make,另一種是利用qmake產生makefile再產生。我這裡用第一種方法沒有成功(原因不詳),這裡說的是第二種方法:
1)進入Qt源碼目錄,~/QtSDK/QtSources/4.8.0/src/plugins/sqldrivers/oci
2) 執行qmake命令, 按照文檔中的說明,執行
- qmake "INCLUDEPATH+=[your_oracle_dir]/instantclient_10_2/sdk/include" "LIBS+=-L[your_oracle_dir]/instantclient_10_2 -Wl,-rpath,[your_oracle_dir]/instantclient_10_2" -lclntsh -lnnz10" oci.pro
這裡的[your_oracle_dir]需要替換為第2步建立的目錄。然後再執行make產生庫檔案。
在執行時make發現無法找到<QtSql/private/qsqlcachedresult_p.h>這個檔案,www.bkjia.com而實際這個檔案在目錄中是有的,原因是預設執行qmake時只把二進位的include目錄QtSDK/Desktop/Qt/4.8.0/gcc/include這個目錄放在INCLUDEPATH中,而這個檔案是在原始碼目錄下,所以會出現無法找到標頭檔的問題。解決辦法是把原始碼的include目錄在qmake時直接添加進去,也就是執行如下的qmake命令:
- qmake "INCLUDEPATH+=[your_oracle_dir]/instantclient_10_2/sdk/include ~/QtSDK/QtSources/4.8.0/include" "LIBS+=-L[your_oracle_dir]/instantclient_10_2 -Wl,-rpath,[your_oracle_dir]/instantclient_10_2" -lclntsh -lnnz10" oci.pro
這樣是可以編譯成功的,但是在最後link時還有一個錯誤,無法找到庫檔案“library not found for -lclntsh”,尋找了oracle的安裝目錄下,確實沒有這個檔案,但有一個libclntsh.dylib.10.1,猜測這個就是一個動態庫,只是版本不同的問題。於是給這個檔案做個符號連結,在[your_oracle_dir]目錄下執行
ln -s libclntsh.dylib.10.1 libclntsh.dylib
然後再回頭去執行make命令,就可以建立成功了。建立後的檔案在~/QtSDK/QtSources/4.8.0/src/plugins/sqldrivers/oci目錄下,把它們複製到Qt的sqldrivers目錄下就可以了。
以上就是整個產生驅動外掛程式的過程。