亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

C語言連接Oracle

系統(tǒng) 2068 0
原文: C語言連接Oracle

最近在搞C語言連接Oracle、DB2數(shù)據(jù)庫,現(xiàn)把C連接Oracle的文章總結(jié)下:

?

用C語言連接ORACLE數(shù)據(jù)庫。
有兩個思路和目的


思路一)
本地環(huán)境:UBUNTU 7.04,ORACLE 10G
目的:用C語連接本地數(shù)據(jù)庫sid:umail,ip:127.0.0.1,用戶名:umail,密碼:umail,表tt1.
顯示表tt1的所有記錄.

思路二)
遠程環(huán)境服務(wù)器1:linux es3
遠程數(shù)據(jù)庫:oracle9i
目的:在遠程一臺服務(wù)器上,再遠程連接數(shù)據(jù)庫,用戶名和表同上
顯示表tt1的所有記錄.

?

一)思路一解決辦法:

1) 查看/etc/profile文件
export ORACLE_BASE=/share/oracle
export ORACLE_HOME=$ORACLE_BASE/product/10.2.1
export ORACLE_SID=umail
export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/usr/lib:$LD_LIBRARY_PATH
export JAVA_HOME=/share/jdk
export AWT_TOOLKIT=MToolkit
作用:解決tnsnames.ora問題

2)更改$ORACLE_HOME/precomp/admin/pcscfg.cfg
sys_include=(/usr/include,/usr/lib/gcc/i486-linux-gnu/4.1.2/include,/usr/lib/gcc/i486-linux-gnu/3.4.6/include,/share/oracle/product/10.2.1/precomp/public,/usr/include/sys)
include=(/share/oracle/product/10.2.1/precomp/public)
include=/share/oracle/product/10.2.1/precomp/hdrs
include=/share/oracle/product/10.2.1/tpcc2x_2/src
include=/share/oracle/product/10.2.1/precomp/precomp/include
include=/share/oracle/product/10.2.1/precomp/oracore/include
include=/share/oracle/product/10.2.1/precomp/oracore/public
include=/share/oracle/product/10.2.1/precomp/rdbms/include
include=/share/oracle/product/10.2.1/precomp/rdbms/public
include=/share/oracle/product/10.2.1/precomp/rdbms/demo
include=/share/oracle/product/10.2.1/precomp/nlsrtl/include
include=/share/oracle/product/10.2.1/precomp/nlsrtl/public
include=/share/oracle/product/10.2.1/precomp/network_src/include
include=/share/oracle/product/10.2.1/precomp/network_src/public
include=/share/oracle/product/10.2.1/precomp/network/include
include=/share/oracle/product/10.2.1/precomp/network/public
include=/share/oracle/product/10.2.1/precomp/plsql/public
ltype=short

?

3)新test.pc文件,如下:

#include <stdio.h>

EXEC SQL INCLUDE SQLCA;

int main()
{
???? //聲明SQL變量
???? EXEC SQL BEGIN DECLARE SECTION;
???? VARCHAR user[20],pass[20],tnsname[20];
???? //VARCHAR預(yù)編譯后為struct { unsigned short len; unsigned char arr[20];}
???? char ename[20];
???? int empno;
???? EXEC SQL END DECLARE SECTION;
????
???? //聲明C變量
???? int i=0;
????
???? //變量賦值
???? strcpy(user.arr,"umail");
???? user.len=(unsigned short)strlen((char *)user.arr);
???? strcpy(pass.arr,"umail");
???? pass.len=(unsigned short)strlen((char *)pass.arr);
???? strcpy(tnsname.arr,"umail");
???? tnsname.len=(unsigned short)strlen((char *)tnsname.arr);
????
???? //連接數(shù)據(jù)庫
???? EXEC SQL CONNECT :user IDENTIFIED BY :pass USING :tnsname;

???? EXEC SQL declare emp_cursor cursor for
????????????????????????????????????????? select id,ename from umail.tt1;

??????????????????????????????????
???? EXEC SQL open emp_cursor;

???? EXEC SQL WHENEVER NOT FOUND DO break;

???? while(1)
???? {
?????????? EXEC SQL fetch emp_cursor into :empno,:ename;
?????????? printf("the empno %d/'s name is %s/n",empno,ename);
?????????? i=i+1;
???? }
????
???? printf("Yeah!We get %d records/n",i);

???? EXEC SQL close emp_cursor;
????
???? EXEC SQL commit work release;
}

?


3)更改tnsname文件如下:


UMAIL =
? (DEscrīptION =
??? (ADDRESS = (PROTOCOL = TCP)(HOST = 127.0.0.1)(PORT = 1521))
??? (CONNECT_DATA =
????? (SERVER = DEDICATED)
????? (SERVICE_NAME = umail)
??? )
? )


EXTPROC_CONNECTION_DATA =
? (DEscrīptION =
??? (ADDRESS_LIST =
????? (ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
??? )
??? (CONNECT_DATA =
????? (SID = PLSExtProc)
????? (PRESENTATION = RO)
??? )
? )

?


4)編譯方法:
預(yù)編譯 proc test.pc
注:這步是依賴于$ORACLE_HOME/precomp/admin/pcscfg.cfg

編譯:
gcc -o test test.c $ORACLE_HOME/lib/libclntsh.so

?

思路二解決辦法:


1)在遠程服務(wù)器上新建一個放tnsname.ora的目錄
mkdir -p /root/network/admin


2)修改tnsname.ora文件,加入遠程數(shù)據(jù)庫信息,如下:
db =
?(DEscrīptION =
??? (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.6.217)(PORT = 1521))
??? (CONNECT_DATA =
????? (SERVER = DEDICATED)
????? (SERVICE_NAME = umail)
??? )
? )


3)將以上的tnsname.ora放入到/root/network/admin下面
scp tnsname.ora 192.168.6.197:/root/network/admin


4)在遠程服務(wù)器上,將/etc/profile修改如下:
增加以下內(nèi)容:
export ORACLE_HOME=/root
用su -加載環(huán)境變量


5)在本地,更改上一個實驗的test.pc文件
????
原內(nèi)容:
strcpy(tnsname.arr,"umail");
tnsname.len=(unsigned short)strlen((char *)tnsname.arr);

更改后的內(nèi)容:
strcpy(tnsname.arr,"db");
tnsname.len=(unsigned short)strlen((char *)tnsname.arr);


6)利用本地環(huán)境重新編譯test.pc

預(yù)編譯 proc test.pc


scp test.c 192.168.6.197:/tmp

編譯:
gcc -o test test.c /usr/lib/libclntsh.so.10.1

?

7)將test上傳到遠程服務(wù)器
scp test 192.168.6.197:/tmp


8)將libclntsh.so.10.1,libnnz10.so上傳到遠程服務(wù)器的/usr/lib下面
scp libclntsh.so.10.1 192.168.6.197:/usr/lib
scp libnnz10.so 192.168.6.197:/usr/lib


9)執(zhí)行測試test
cd /tmp;./test

C語言連接Oracle


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 成年女人看片免费视频频 | 欧美日韩不卡视频 | 成人毛片18岁女人毛片免费看 | 秋霞在线观看成人高清视频51 | 视频二区中文字幕 | 伊人久久大杳蕉综合大象 | 奇米在线免费视频 | 插吧插吧综合网 | 国产福利在线 | 国产成人免费手机在线观看视频 | 国产成人综合精品 | 免费黄片毛片 | 色视频一区二区三区 | 动漫精品一区二区3d | 久热在线视频精品网站 | 新香蕉视频在线 | 欧美成人禁片在线观看网址 | 久久国产精品吴梦梦 | 久操国产视频 | 亚洲人成绝费网站色ww | 欧美精品视 | 日韩福利影院 | 亚洲成人日韩 | 欧美一级毛片香蕉网 | 久久久影院 | 看大片全色黄大色黄 | 亚洲精品天堂一区二区三区 | 欧美性生活视频免费 | 国产成人精品高清在线观看99 | 亚洲爱爱视频 | 日韩字幕 | 亚洲四虎影院 | 中文字幕一区二区三区在线观看 | 特级a欧美做爰片毛片 | 亚洲va欧美va | 欧美一级特黄毛片免费 | 国产免费一级高清淫日本片 | 色婷婷久久综合中文网站 | 日韩在线观看中文字幕 | 欧美日本高清动作片www网站 | 9999热|