


下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、SQL Server調(diào)用Oracle的存儲(chǔ)過程收藏原文如下:通過SQL Linked Server 執(zhí)行0rac 1 e存儲(chǔ)過程小結(jié)1舉例我們可以通過下面的方法在SQL Server中通過Linked Server來執(zhí)行Oracle存儲(chǔ)過 程。(1) Oracle PackagePACKAGE Test PACKAGE ASTYPE t_t is TABLE of VARCHAR2(30)INDEX BY BINARY,INTEGER;PROCEDURE Test procedure1(p BATCHD IN VARCHAR2,p_Number IN number,P.MSG OUT t_t.
2、p MSG1 OUT t_t);END Test PACKAGE;PACKAGE BODY Test PACKAGE ASPROCEDURE Test procedure1(p BATCH一ID IN VARCHAR2,p Number IN number,P.MSG OUT t_t,p MSG1 OUT t_t)ASBEGINp. MSGp. MSG(2): = ,b,;p. MSG(3)=a;p MSGl(l): = Qbc;RETURN;MIT;EXCEPTIONWHEN OTHERS THENROLLBACK;END Test procedure1;END Test PACKAGE;(
3、2) 在SQL Server中通過Linked Server 來執(zhí)行Oracle 存儲(chǔ)過程declare BatchID nvarchar (40)declare QueryStr nvarchar (1024)declare StatusCode nvarchar(100)declare sq1 nvarchar(1024)set BatchID=,AM*SET QueryStr=, CALL GSN. Test_PACKAGE. Test_procedurel(* * *1,+BatchID+,1'".八'4'''.resultset 3.
4、 p_MSG.resultset 1, p_ MSG1)1(3) 執(zhí)行結(jié)果(a)select sql=rSELECT StatusCode=p. msg FROM OPENQUERY (HI4DB_MS,r11-QueryStr+''')'exec sp executesql sql,NfStatusCode nvarchar(100) output*,StatusCode outpu tprint StatusCode答案:StatusCode=, a'(b) select sql=fSELECT top 3 StatusCode=p_msg FROM
5、 OPENQUERY (HI4DB MS,-QueryStr+,F)rexec sp_executesql sql,N1StatusCode nvarchar(100) output *.StatusCode outpu print StatusCode答案:StatusCode=, a(c)select sql=fSELECT top 2 StatusCode=p_msg FROM OPENQUERY (HI4DB MS,1r r -QueryStr+,f)rexec sp_executesql sql.N1StatusCode nvarchar(100) outputr.StatusCod
6、e outpu tprint StatusCode答案:StatusCode=, b'(d)select sql=rSELECT top 1 StatusCode=p_msg FROM OPENQUERY (HI4DB MS,1'r-QueryStr+,f)rexec sp executesql sqlStatusCode nvarchar(100) output1,StatusCode outpu print StatusCode答案:StatusCode二'c(e)SET QueryStr=,CALL GSN. Test.PACKAGE. Test procedur
7、e1C11f,+BatchID+,11 *r / 1''4'' '' resultset 1, p. MSG1. resultset 3. p_MSG)'(注意這里 p_MSG1 和P MSG交換次序了)EXEC(rSELECT pmsgl FROM OPENQUERY (HI4DB MS/r,-QueryStr+,r1)r) select sql=rSELECT StatusCode=p_msgl FROM OPENQUERY (HI4DB MS/r,-QuerySexec sp executesql sql,N*StatusCode
8、nvarchar(100) output*,StatusCode outpuprint StatusCode答案:StatusCode=" abc*2上述使用方法的條件(1) Link Server 要使用 Microsoft 的 Driver (Microsoft OLE DB Provider fo r Oracle)(2) Oracle Package中的Procedure的返回參數(shù)是Table類型,目前table只試成功一個(gè)欄位。(3) SQL Server 的 Store Procedure 調(diào)用 Oracle Procedure 時(shí),返回參數(shù)名字必須 和 Procedur
9、e 相同。3上述方法的要點(diǎn)(1) 如果要實(shí)現(xiàn)"Oracle和SQL Server數(shù)據(jù)庫”之間的Trans處理,則Oracle的Proc edure 不要有 mit, rollback 等語句,讓 SQL Server 的 Store Procedure 去控制整個(gè) Tra ns何時(shí)mito(2) 假如返回參數(shù)大于1個(gè),返回參數(shù)的次序可以調(diào)換,調(diào)用時(shí)只返回第一個(gè)出現(xiàn)的返回 參數(shù),如上面的執(zhí)行結(jié)果(e)。但是輸入?yún)?shù)和返回參數(shù)的順序不能調(diào)換。(3) resultset n, p. MSGl,這里的n,表示返回表的行數(shù)。N可以大于等于實(shí)際的 行數(shù),但不能小于實(shí)際的行數(shù),會(huì)報(bào)錯(cuò)。(4) 假如
10、返回表有多行記錄,執(zhí)行select sql=rSELECT StatusCode=pmsg FROM OPENQUERY (HI4DB ''+Qu eryStr+,")'exec sp executesql sql,N*StatusCode nvarchar(100) output*,StatusCode outpu tprint StatusCode, StatusCode中的值為最后一行記錄的值,如執(zhí)行結(jié)果(a)。4動(dòng)態(tài)SQL語句(1) 普通SQL語句可以用Exec執(zhí)行egSelect * from MCITYExec (* select * from M
11、CITY)sp_executesql N'select * from tableName串前一定要加N一請(qǐng)注意字符(2) 字段名,表名,數(shù)搖庫名之類作為變量時(shí),必須用動(dòng)態(tài)SQLeg: declare FielsNamevarchar (20)declare sqls nvarchar (1000)set F i e1sName'CITY'Select FielsName from MCITYExec (rselect '+ FielsName +1 from MCITY *)請(qǐng)注意加號(hào)前后的單引號(hào)的邊上要加空格set sqls=,select+ FielsNam
12、e +' from MCITYexec sp_executesql sqls當(dāng)然將字符串改成變量的形式也可declare s varchar (1000)1 select *+ FielsName +' from MCITY1Exec(s)成功exec sp executesql s此句會(huì)報(bào)錯(cuò)declare s Nvarchar (1000)注意此處改為nvarchar (1000)set* select '+ fname+1 from from MCITYrExec(s)成功exec sp_executesql s此句正確(3) 輸出參數(shù) eg: declare nu
13、m int declare sqls nvarchar (1000)declarestrTableName nvarchar(55) set strTableName=,MCITY*+strTableNameset sqls=,select count() from 'exec (sqls)如何能將exec執(zhí)行的結(jié)果存入變量num中declarenum intdeclaresqls nvarchar(1000)declarestrTableName nvarchar (55)setstrTableName=,MCITY,setsqls=,select a=count (*) fi'om r +strTab 1 eNameexecsp executesql sqls,Nfa int output1,num outputselectnum(注:以上
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 【正版授權(quán)】 IEC 60270:2025 EN-FR High-voltage test techniques – Charge-based measurement of partial discharges
- 2025至2030中國電子廢物回收和再利用服務(wù)行業(yè)產(chǎn)業(yè)運(yùn)行態(tài)勢及投資規(guī)劃深度研究報(bào)告
- 2025至2030中國環(huán)氧大豆油丙烯酸酯低聚物行業(yè)產(chǎn)業(yè)運(yùn)行態(tài)勢及投資規(guī)劃深度研究報(bào)告
- 2025至2030中國豬肉行業(yè)市場占有率及投資前景評(píng)估規(guī)劃報(bào)告
- 2025至2030中國特性水泥行業(yè)發(fā)展分析及前景趨勢與投資報(bào)告
- 智慧城市服務(wù)體系下市民滿意度提升策略研究
- 在線學(xué)習(xí)環(huán)境下的學(xué)生心理支持策略研究
- 企業(yè)培訓(xùn)中的智慧學(xué)習(xí)空間設(shè)計(jì)與體驗(yàn)優(yōu)化
- 教育政策與教師權(quán)益保障
- 2025年中國乙炔碳黑數(shù)據(jù)監(jiān)測研究報(bào)告
- 變電站電氣安裝合同
- 電儀檢修面試試題及答案
- 記憶力提升圖書出版行業(yè)深度調(diào)研及發(fā)展戰(zhàn)略咨詢報(bào)告
- 沈陽地鐵筆試試題及答案
- 雙減政策中的課程改革探索心得體會(huì)
- 2024-2025學(xué)年人教版英語七年級(jí)下冊(cè)Unit 5 Here and now Section A 2a - 2e 教案
- 一維伺服移動(dòng)工作臺(tái)設(shè)計(jì)說明書電子精密機(jī)械設(shè)計(jì)課程設(shè)計(jì)
- 職工代表選舉方案及選票模版(2篇)
- 血透室護(hù)理安全管理及防范
- 電商直播平臺(tái)主播操作手冊(cè)
- ASTM-D3359-(附著力測試標(biāo)準(zhǔn))-中文版
評(píng)論
0/150
提交評(píng)論