失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > SQL 链接Oracle 调用存储过程

SQL 链接Oracle 调用存储过程

时间:2019-11-06 16:43:30

相关推荐

SQL 链接Oracle 调用存储过程

最近接触了两个项目都用到了SQL与Oracle数据互通,其中一个数据同步还要调用ORACLE中的存储过程来执行相应的操作。

1. SQL链接ORACLE 都是可视化的操作 如下图:

红色框选的是oracle的数据驱动,如果没有这个驱动 那需要单独安装oracle的client端 装完以后就有了。

2.在创建之前,在SQLSERVER中,链接服务器->访问接口->OraOLEDB.Oracle->右键属性,选中 “Allow inprocess” (中文为:允许进程内)

这一步是使我们选择的OraOLEDB.Oracle接口打开执行操作。

如未设置会报如下错误:“无法初始化链接服务器 “null” 的 OLE DB 访问接口 “OraOLEDB.Oracle” 的数据源对象”

3.创建好链接服务就可以在SQL端通过语句查询oracel的数据了 提供了两种查询方式

1.SELECT* FROM 链接服务器名字..登录用户名.表名注意:必须要全大写

这种方式可以进行操作,优点是使用简单,一目了然,而缺点是性能太差,查询大数据量表很慢。效率太差。

2.select * from openquery(链接服务器名字,’select * from oracle_table_name’);

带查询参数:select * from openquery(链接服务器名字,’select * from test’) where test_id=10; test_id 是test表的字段

关于链接服务查询 推荐方式2 速度更快。

4.SQL调用oracle的存储过程

--oracle创建存储过程CREATE OR REPLACE PROCEDURE SHOW_PROC(DEPT_NO INT, V_NAME OUT VARCHAR) ISBEGINSELECT D.DNAME INTO V_NAME FROM DEPT D WHERE D.DEPTNO = DEPT_NO;END;

一个传入参数 一个返回参数。就是通过部门ID 返回部门名字

SQL端调用

declare @DEPTNO INT;--传入参数declare @V_NAME VARCHAR(20);--返回参数SET @DEPTNO=10;-- 调用存储过程EXEC('BEGIN SHOW_PROC(?,?);END;',@DEPTNO,@V_NAME output) at NC;print(@V_NAME);

这里要注意返回参数,一定要加上Output,不然会报错。

感谢这位博主的文章 解决我很大的问题 给我帮助很多 特别是调用oracle的存储过程。/s/blog_614b6f210100t80r.html

如果觉得《SQL 链接Oracle 调用存储过程》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。