1、參考文檔
工欲善其事,必先利其器。Oracle官方參考文檔:Oracle Document。裡面有各種文檔,其中有兩本是關於oci和occi的。
c語言《Oracle Call Interface Programmer's Guide》和c++語言《Oracle C++ Call Interface Programmer's Guide》。
2、vs2005 開發環境搭建
本文只介紹OCCI開發環境的搭建,關於oci開發環境,基本等同。
2.1、下載庫和標頭檔
:http://www.oracle.com/technetwork/topics/winsoft-085727.html?ssSourceSiteId=ocomen
由於10.2版本的instant client沒有支援vs2005的動態庫,即使編譯成功,運行時也會報各種奇奇怪怪的問題,所以選擇支援vs2005的11.2.0.3.0版本。
搭建開發環境需下載兩個檔案:
- instantclient-basic-nt-11.2.0.3.0.zip。這個包包含運行OCCI程式的動態連結程式庫。
- instantclient-sdk-nt-11.2.0.3.0.zip。這個包包含開發庫的標頭檔、靜態連結庫以及occi樣本程式。
2.2、配置
解壓2.1中下載的兩個包。
OCCI項目的屬性-》配置屬性-》C/C++-》常規-》附加元件封裝含目錄 中添加解壓後的“instantclient_11_2\sdk\include”目錄;
OCCI項目的屬性-》配置屬性-》連接器-》常規-》附加庫目錄 中添加解壓後的“instantclient_11_2\sdk\lib\msvc\vc8”目錄;
OCCI項目的屬性-》配置屬性-》連接器-》輸入-》附加依賴項 中添加oraocci11.lib庫。
將解壓後的instantclient_11_2目錄中的dll檔案拷貝至編譯的可執行檔目錄。
3、搭建開發環境中遇到的問題3.1、10.2版本的問題
由於系統原本安裝了10.2版本的Oracle client 。安裝用戶端時會自動安裝oci開發庫。原本想用10.2版本的庫,哪知道這個版本不支援vs2005,編譯能正常通過,可運行時就會報奇奇怪怪的錯誤。最後只好重新下載11.2的開發庫。
3.2、linux開發環境的搭建
linux環境搭建和vs2005開發環境搭建差不多。由於linxu上沒有安裝oracle資料庫和用戶端,因此沒有什麼幹擾。直接在ldconf中添加了動態連結程式庫目錄,這樣就不用把動態連結程式庫拷貝到可執行程式目錄了。當然在win32開發環境中,如果不想拷貝動態連結程式庫,你也可以在環境變數PATH中進行設定。
3.3、關於demo
對於下載包中的demo,不要指望直接編譯就能運行。你需要根據自己的系統修改demo.mk檔案。
3.4、中文亂碼問題
如果你在查詢中文顯示亂碼,極有可能是字元集問題。
使用sqlplus查詢:
SQL>select userenv('language') from dual;
查詢到服務端的字元集設定是SIMPLIFIED CHINESE_CHINA.ZHS16GBK
建立環境變數函數裡可以直接指定字元集,於是如下建立環境變數:
env = Environment::createEnvironment ("ZHS16GBK","ZHS16GBK")
字元集配對了,就不會產生亂碼。