日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

[转]嵌入式SQC文件编译

發(fā)布時間:2023/12/13 综合教程 37 生活家
生活随笔 收集整理的這篇文章主要介紹了 [转]嵌入式SQC文件编译 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.


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語句變?yōu)镈B2數據庫可認的API。bind的作用主要是根據你SQC中的SQL語句使用的表和操作指定一個訪
問時DB要使用的策略,是一種優(yōu)化作用,加快數據訪問的速度;當然也可以不bind,那樣,訪問的過程策略是在訪問時才有的,速度會受很大的影響,特別是
并發(fā)訪問。



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的一般編譯命令請參考文檔中的相關說明,這里具體說明在目前環(huán)境下編譯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用戶的環(huán)境變
量中,再次創(chuàng)建instance后只要復制過來就可以,因為Instance用戶還包含其他的環(huán)境設定,所以不要直接引用-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)編譯成可執(zhí)行程序


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下。

總結

以上是生活随笔為你收集整理的[转]嵌入式SQC文件编译的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。