Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1369706
  • 博文数量: 172
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 3831
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-30 13:00
个人简介

About me:Oracle ACE pro,optimistic,passionate and harmonious. Focus on ORACLE,MySQL and other database programming,peformance tuning,db design, j2ee,Linux/AIX,Architecture tech,etc

文章分类

全部博文(172)

文章存档

2024年(27)

2023年(28)

2022年(43)

2020年(62)

2014年(3)

2013年(9)

分类: Oracle

2022-04-12 08:43:10

在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作为媒介,从而很容易实现这个功能。
阅读(3680) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~