Chinaunix首页 | 论坛 | 博客

e

  • 博客访问: 120801
  • 博文数量: 15
  • 博客积分: 2041
  • 博客等级: 大尉
  • 技术积分: 197
  • 用 户 组: 管理员
  • 注册时间: 2012-02-12 10:26
个人简介

木有介绍 爱咋咋地

文章分类

全部博文(15)

分类: Oracle

2013-05-16 14:00:08

     在SQL中可以调用自定义函数,但是不能够调用存储过程。SQL中调用自定义函数有一定的限制,如果是查询语句,则不可有DML操作,除非使用匿名事务AT。当然,在UPDATE,DELETE中使用的自定义函数可以带DML操作。

     如何用SQL调用存储过程呢?因为SQL只能调用自定义函数,但是自定义函数可以调用存储过程,因此,可以SQL----调用FUNCTION---调用PROCEDURE来间接实现SQL调用函数。如下例:

 SQL> CREATE OR REPLACE PROCEDURE test_prc(var1 IN number,var2 OUT NUMBER)
  2  AS
  3  BEGIN
  4   var2 := var1+1;
  5  END;
  6  /
 
Procedure created
 
SQL> 
SQL> CREATE OR REPLACE FUNCTION test_func(var1 IN NUMBER)
  2  RETURN NUMBER
  3  AS
  4  var2 NUMBER;
  5  BEGIN
  6   test_prc(var1,var2);
  7   RETURN var2;
  8  END;
  9  /
 
Function created
 
SQL> SELECT test_func(1) FROM dual;
 
TEST_FUNC(1)
------------
           2

     在程序编写过程中,如果直接不行,就需要用间接手段,SQL调用存储过程,使用自定义FUNCTION作为媒介,从而很容易实现这个功能。



  
阅读(2800) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~