Mac系統下編譯Oracle的SQL Drivers外掛程式qsqloci

來源:互聯網
上載者:User

今天編譯在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命令, 按照文檔中的說明,執行

  1. 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命令:

  1. 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目錄下就可以了。

以上就是整個產生驅動外掛程式的過程。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.