Src Url:http://blog.csdn.net/cws1214/article/details/12996351
A.預編譯部分
1.預編譯DB2篇
1.1 什麼是DB2預編譯
在咱們用C語言編寫訪問DB2的程序過程當中,須要用到嵌入式SQL,其做用是將DB2 SQL混入通常C程序中, DB2預編譯器能夠將SQL語法直接轉換爲DB2行時服務應用程序編程接口(API)調用。
1.2 什麼是bind
這是DB2 prep要作的事情,即把SQC中的SQL語句變爲DB2數據庫可認的API。bind的做用主要是根據你SQC中的SQL語句使用的表和操做指定一個訪 問時DB要使用的策略,是一種優化做用,加快數據訪問的速度;固然也能夠不bind,那樣,訪問的過程策略是在訪問時纔有的,速度會受很大的影響,特別是 併發訪問。
2.預編譯命令
2.1 db2 prep .sqc文件 bindfile 其中bindfile參數做用是生成和sqc文件同名的.bnd文件
例: db2 prep /export/home/shwhome/sqc/CON_DB2.sqc bindfile 若是編譯正常完成,則在.sqc文件同目錄下會生成CON_DB2.c和CON_DB2.bnd文件
2.2 bind .bnd文件
例: db2 bind /export/home/shwhome/sqc/CON_DB2.bnd
由於是DB2的預編譯命令,使用的是DB2的預編譯器,因此以上兩條命令須要在鏈接DB2數據庫的狀況下才可使用
B.嵌入式部分
1.嵌入式C程序的編譯
咱們採用GCC來編譯C程序,GCC的通常編譯命令請參考文檔中的相關說明,這裏具體說明在目前環境下編譯C程序的注意點。
1.1 編譯C程序
gcc -m64 -c -I/export/home/shwhome/inc -o /export/home/shwhome/obj/testdb.o /export/home/shwhome/src/testdb.c
參數說明
-m64: 在64位服務器上編譯時採用,這裏爲了將全部的編譯後的目標文件統一,因此都加上-m64,若是再以後引用目標文件沒有采用-m64編譯則在最後編譯時會 出現ELF CLASS32(或ELF CLASS64)錯誤. -C: 只編譯並生成目標文件,不作連接。
1.2 編譯SQC文件生成的.C文件
gcc -m64 -c -I/export/home/shwhome/inc -I/export/home/aix/sqllib/include -L/usr/include/lib -o /export/home/shwhome/obj/CON_DB2.o /export/home/shwhome/sqc/CON_DB2.c
參數說明
-I/export/home/aix/sqllib/include: 這個目錄下主要使用到2個頭文件:sqladef.h和sqlca.h,這個是DB2預編譯包含的都文件,能夠查看你用prep編譯出來的與.sqc同名 的.C文件,其中就包含這兩個頭文件。其中aix是DB2Instance用戶,DB2安裝後會將include路徑複製到instance用戶的環境變 量中,再次建立instance後只要複製過來就能夠,由於Instance用戶還包含其餘的環境設定,因此不要直接引用-I/opt/IBM/db2 /V9.5/include/這個DB2的安裝路徑
-L/usr/include/lib: 這個目錄是系統包含函數的庫文件,是編寫應用程序的時候使用的至關於API,也就是應用編程接口。
※ -I/usr/include和-L/usr/include/lib是將usr/include下的函數做爲頭文件包括進來,而且將程序連接到庫文件,這個例子中沒有用到,可是若是保險的話,在編譯時最好加上這兩個選項。
1.3 將兩個目標文件(主體C程序和嵌入式SQL)編譯成可執行程序
gcc -m64 -ldb2 -lc -o /export/home/shwhome/bin/testdb /export/home/shwhome/obj/CON_DB2.o /export/home/shwhome/obj/testdb.o
參數說明
-ldb2: 連接DB2庫文件。在SQC程序編譯時必須連接libdb2.so庫,其路徑是/usr/lib/krb5/libdb2.so,之因此寫成-ldb2, 是在使用-l時,將庫名的lib和後綴都去除,即庫名是db2。以上命令是引用/export/home/shwhome/obj/CON_DB2.o /export/home/shwhome/obj/testdb.o這兩個目標文件,編譯後生成testdb,放在路徑/export/home /shwhome/bin下。