在Oracle數(shù)據(jù)庫中使用PL操作COM對(duì)象
上一篇文章我們主要講述的是如何在Oracle數(shù)據(jù)庫中使用PL/SQL操作COM對(duì)象,以下的文章那個(gè)我們即那個(gè)要講述的是在Oracle數(shù)據(jù)庫中使用COM對(duì)象的說明的具體內(nèi)容的介紹,以下就是文章內(nèi)容的詳細(xì)描述。
使用COM對(duì)象說明
COM對(duì)象設(shè)計(jì)都會(huì)提供了三個(gè)基本操作給開發(fā)人員使用,分別為:獲取屬性值,設(shè)置屬性值(只讀屬性除外),調(diào)用方法。oracle數(shù)據(jù)庫在Windows的平臺(tái)下提供了操作COM對(duì)象的接口,屬于C語言外部例程模式。在使用該功能之前,需明白如下內(nèi)容:
1) 在Oracle數(shù)據(jù)庫中使用PL/SQL創(chuàng)建COM對(duì)象操作函數(shù)。
- SQL> CONNECT SYSTEM/chanet@oradb
 - SQL> CREATE USER chanet identified by chanet;
 - SQL> GRANT CREATE LIBRARY TO chanet;
 - SQL> CONNECT chanet/chanet@oradb;
 - SQL> @D:oracleora92comcomwrap.sql;
 
2)配置監(jiān)聽器。
在listener.ora文件里,添加如下內(nèi)容,并重啟監(jiān)聽器。
- STARTUP_WAIT_TIME_LISTENER = 0
 - CONNECT_TIMEOUT_LISTENER = 10
 - TRACE_LEVEL_LISTENER = off
 - PASSWORDS_LINTENER = (oracle)
 
3) PL/SQL數(shù)據(jù)類型與對(duì)應(yīng)的COM對(duì)象類型
表1-1數(shù)據(jù)類型比較
PL/SQL數(shù)據(jù)類型 COM API 數(shù)據(jù)類型
- VARCHAR2 BSTR
 - BOOLEAN BOOL
 - BINARY_INTEGER BYTE,INT,LONG
 - DOUBLE PRECISION DOUBLE,F(xiàn)LOAT,CURRENCY
 - DATE DATE
 
4) 函數(shù)說明。
表1-2函數(shù)說明
名稱 功能描述
CreateObject 創(chuàng)建對(duì)象
DestroyObject 關(guān)閉對(duì)象
GetLastError 獲取錯(cuò)誤信息
GetProperty 獲取屬性值
SetProperty 設(shè)置屬性值
InitArg 為Invoke函數(shù)初始化參數(shù)
InitOutArg 為GetArg初始化輸出參數(shù)
GetArg 獲取輸出參數(shù)
SetArg 為Invoke函數(shù)設(shè)置參數(shù)
Invoke 調(diào)用Oracle數(shù)據(jù)庫中使用PL/SQL操作COM對(duì)象的函數(shù)或過程
5) 操作Excel示例
本節(jié)介紹如何操作COM對(duì)象(以Excel對(duì)象為例),將數(shù)據(jù)庫里的表記錄通過PL/SQL語句輸出成Excel文件。通過對(duì)象瀏覽器可以查看Excel對(duì)象提供的屬性和方法。(如:在Excel菜單,工具 -> 宏 -> 打開Visual Basic編輯器,在編輯器里,視圖 -> 對(duì)象瀏覽器)。
使用Excel對(duì)象一般針對(duì)單元格進(jìn)行操作(如,設(shè)置第一個(gè)單元格字體大小的代碼為:Range("A1").Font.Size = 20)。對(duì)應(yīng)的COM外部例程操作的步驟為:
1、獲取程序句柄;
2、獲取工作簿句柄;
3、獲取工作表句柄;
4、獲取Range區(qū)句柄;
5、獲取Font類句柄;
6、設(shè)置Size屬性。
以上的相關(guān)內(nèi)容就是對(duì)Oracle數(shù)據(jù)庫中使用PL/SQL操作COM對(duì)象的介紹,望你能有所收獲。
【編輯推薦】
- 歸檔解決方案等多項(xiàng)技術(shù)和功能
 - LTO歸檔解決方案容量、性能和功能介紹
 - 歸檔解決方案進(jìn)行自動(dòng)精簡配置
 - 日立歸檔平臺(tái)支持SAP 應(yīng)用程序數(shù)據(jù)
 - 惠普郵件歸檔平臺(tái)運(yùn)用存儲(chǔ)網(wǎng)格技術(shù)
 















 
 
 
 
 
 
 