




已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
SQL Server 调用Oracle的存储过程 收藏 原文如下:通过SQLLinkedServer执行Oracle存储过程小结1 举例我们可以通过下面的方法在SQLServer中通过LinkedServer来执行Oracle存储过程。(1)OraclePackagePACKAGETest_PACKAGEASTYPEt_tisTABLEofVARCHAR2(30)INDEXBYBINARY_INTEGER;PROCEDURETest_procedure1(p_BATCH_IDINVARCHAR2,p_NumberINnumber,p_MSGOUTt_t,p_MSG1OUTt_t);ENDTest_PACKAGE;PACKAGEBODYTest_PACKAGEASPROCEDURETest_procedure1(p_BATCH_IDINVARCHAR2,p_NumberINnumber,p_MSGOUTt_t,p_MSG1OUTt_t)ASBEGINp_MSG(1):=c;p_MSG(2):=b;p_MSG(3):=a;p_MSG1(1):=abc;RETURN;COMMIT;EXCEPTIONWHENOTHERSTHENROLLBACK;ENDTest_procedure1;ENDTest_PACKAGE;(2)在SQLServer中通过LinkedServer来执行Oracle存储过程declareBatchIDnvarchar(40)declareQueryStrnvarchar(1024)declareStatusCodenvarchar(100)declaresqlnvarchar(1024)setBatchID=AAASETQueryStr=CALLGSN.Test_PACKAGE.Test_procedure1(+BatchID+,4,resultset3,p_MSG,resultset1,p_MSG1)(3)执行结果(a)selectsql=SELECTStatusCode=p_msgFROMOPENQUERY(HI4DB_MS,+QueryStr+)execsp_executesqlsql,NStatusCodenvarchar(100)output,StatusCodeoutputprintStatusCode答案:StatusCode=a(b)selectsql=SELECTtop3StatusCode=p_msgFROMOPENQUERY(HI4DB_MS,+QueryStr+)execsp_executesqlsql,NStatusCodenvarchar(100)output,StatusCodeoutputprintStatusCode答案:StatusCode=a(c)selectsql=SELECTtop2StatusCode=p_msgFROMOPENQUERY(HI4DB_MS,+QueryStr+)execsp_executesqlsql,NStatusCodenvarchar(100)output,StatusCodeoutputprintStatusCode答案:StatusCode=b(d)selectsql=SELECTtop1StatusCode=p_msgFROMOPENQUERY(HI4DB_MS,+QueryStr+)execsp_executesqlsql,NStatusCodenvarchar(100)output,StatusCodeoutputprintStatusCode答案:StatusCode=c(e)SETQueryStr=CALLGSN.Test_PACKAGE.Test_procedure1(+BatchID+,4,resultset1,p_MSG1,resultset3,p_MSG)-(注意这里p_MSG1和p_MSG交换次序了)EXEC(SELECTp_msg1FROMOPENQUERY(HI4DB_MS,+QueryStr+)selectsql=SELECTStatusCode=p_msg1FROMOPENQUERY(HI4DB_MS,+QueryStr+)execsp_executesqlsql,NStatusCodenvarchar(100)output,StatusCodeoutputprintStatusCode答案:StatusCode=abc2 上述使用方法的条件(1)LinkServer要使用Microsoft的Driver(MicrosoftOLEDBProviderforOracle)(2)OraclePackage中的Procedure的返回参数是Table类型,目前table只试成功一个栏位。(3)SQLServer的StoreProcedure调用OracleProcedure时,返回参数名字必须和Procedure相同。3 上述方法的要点(1)如果要实现“Oracle和SQLServer数据库”之间的Trans处理,则Oracle的Procedure不要有Commit,rollback等语句,让SQLServer的StoreProcedure去控制整个Trans何时commit。(2)假如返回参数大于1个,返回参数的次序可以调换,调用时只返回第一个出现的返回参数,如上面的执行结果(e)。但是输入参数和返回参数的顺序不能调换。(3)resultsetn,p_MSG1,这里的n,表示返回表的行数。N可以大于等于实际的行数,但不能小于实际的行数,会报错。(4)假如返回表有多行记录,执行 selectsql=SELECTStatusCode=p_msgFROMOPENQUERY(HI4DB_MS,+QueryStr+)execsp_executesqlsql,NStatusCodenvarchar(100)output,StatusCodeoutputprintStatusCode,StatusCode中的值为最后一行记录的值,如执行结果(a)。4 动态SQL语句(1)普通SQL语句可以用Exec执行eg:Select*fromMCITYExec(select*fromMCITY)sp_executesqlNselect*fromtableName-请注意字符串前一定要加N(2)字段名,表名,数据库名之类作为变量时,必须用动态SQLeg:declareFielsNamevarchar(20)declaresqlsnvarchar(1000)setFielsName=CITYSelectFielsNamefromMCITY-错误Exec(select+FielsName+fromMCITY)-请注意加号前后的单引号的边上要加空格setsqls=select+FielsName+fromMCITYexecsp_executesqlsqls当然将字符串改成变量的形式也可declaresvarchar(1000)sets=select+FielsName+fromMCITYExec(s)-成功execsp_executesqls-此句会报错declaresNvarchar(1000)-注意此处改为nvarchar(1000)sets=select+fname+fromfromMCITYExec(s)-成功execsp_executesqls-此句正确(3)输出参数eg:declarenumintdeclaresqlsnvarchar(1000)declarestrTableNamenvarchar(55)setstrTableName=MCITYsetsqls=selectcount(*)from+strTableNameexec(sqls)如何能将exec执行的结果存入变量num中declarenumintdeclaresqlsnvarchar(1000)declarestrTableNamenvarchar(55)setstrTableName=MCITYsetsqls=selecta=count(*)from+strTableNameexecsp_executesqlsqls,Naintoutput,numoutputselectnum(注:以上SQL在sv-02,Qservice下测试通
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 江苏省常州市2025年中考物理真题附真题答案
- 安全教育培训闭幕词课件
- 蔻驰ai面试题库大全及答案
- 安全教育培训课程开发课件
- 安全教育培训课时安排课件
- 学前教育机构师资队伍教育政策对师资队伍影响研究报告
- 海洋能发电技术创新驱动2025年海岛能源供应体系升级报告
- 农业与食品行业绿色生产技术发展研究报告
- 银行零售业务数字化营销转型中的金融营销策略创新实践报告
- 新能源行业安全生产标准化建设与新能源电池安全2025年报告
- 混凝土模板工程验收表(含续表)GDAQ2090202
- GB/T 29466-2023板式热交换器机组
- 多模态大模型技术演进及研究框架
- 中国教育史全套
- GB/T 818-2000十字槽盘头螺钉
- GB/T 31298-2014TC4钛合金厚板
- 口腔科中医临床诊疗技术
- itop-4412开发板之精英版使用手册
- 老年肌肉衰减综合征肌少症培训课件
- 中学生物学教学技能与实践课件
- 井喷失控事故案例教育-井筒工程处课件
评论
0/150
提交评论