SQL中调用ORACLE存储过程.doc

上传人:飞****2 文档编号:54340712 上传时间:2022-10-28 格式:DOC 页数:6 大小:24KB
返回 下载 相关 举报
SQL中调用ORACLE存储过程.doc_第1页
第1页 / 共6页
SQL中调用ORACLE存储过程.doc_第2页
第2页 / 共6页
点击查看更多>>
资源描述

《SQL中调用ORACLE存储过程.doc》由会员分享,可在线阅读,更多相关《SQL中调用ORACLE存储过程.doc(6页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

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);ENDTes

2、t_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存

3、储过程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+)ex

4、ecsp_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

5、=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答案:Sta

6、tusCode=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)outpu

7、t,StatusCodeoutputprintStatusCode答案:StatusCode=abc2 上述使用方法的条件(1)LinkServer要使用Microsoft的Driver(MicrosoftOLEDBProviderforOracle)(2)OraclePackage中的Procedure的返回参数是Table类型,目前table只试成功一个栏位。(3)SQLServer的StoreProcedure调用OracleProcedure时,返回参数名字必须和Procedure相同。3 上述方法的要点(1)如果要实现“Oracle和SQLServer数据库”之间的Trans处理,则

8、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

9、+)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)declar

10、esqlsnvarchar(1000)setFielsName=CITYSelectFielsNamefromMCITY-错误Exec(select+FielsName+fromMCITY)-请注意加号前后的单引号的边上要加空格setsqls=select+FielsName+fromMCITYexecsp_executesqlsqls当然将字符串改成变量的形式也可declaresvarchar(1000)sets=select+FielsName+fromMCITYExec(s)-成功execsp_executesqls-此句会报错declaresNvarchar(1000)-注意此处改为n

11、varchar(1000)sets=select+fname+fromfromMCITYExec(s)-成功execsp_executesqls-此句正确(3)输出参数eg:declarenumintdeclaresqlsnvarchar(1000)declarestrTableNamenvarchar(55)setstrTableName=MCITYsetsqls=selectcount(*)from+strTableNameexec(sqls)如何能将exec执行的结果存入变量num中declarenumintdeclaresqlsnvarchar(1000)declarestrTable

12、Namenvarchar(55)setstrTableName=MCITYsetsqls=selecta=count(*)from+strTableNameexecsp_executesqlsqls,Naintoutput,numoutputselectnum(注:以上SQL在sv-02,Qservice下测试通过。) 删除重复数据:delete top(1) from table where name in( select name from table group by name having count(name)1 )SELECT *FROM table WHERE (id IN(SELECT MAX(id) FROM table GROUP BY name)

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁