【转】几个常用的Oracle存储过程

http://blog.bossma.cn/database/some-oracle-storing-process/

几个常用的Oracle存储过程

发布时间:2008年1月6日 / 分类:DataBase / 7,268 次浏览 / 评论

初学Oracle,了解了一下Oracle的存储过程,运行了几个例子,做个备忘,方便以后使用:
1、插入数据:
向一张表里插入若干条数据

0

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

/*

创建表tb1

包含两个字段col1、col2

*/

create table tb1(

col1 char(20),

col2 char(20));

/*插入数据的存储过程*/

CREATE OR REPLACE PROCEDURE INSERTAMOUNTTEST

(

ST_NUM        IN     NUMBER,/*起始数值*/

ED_NUM        IN     NUMBER/*结束数值*/

)

IS

BEGIN

declare

i   number;

begin

/*循环插入*/

FOR i IN ST_NUM..ED_NUM LOOP

INSERT INTO tb1 values(i,‘test‘);

END LOOP;

end;

commit;

/*异常处理*/

EXCEPTION

WHEN OTHERS THEN

rollback;

END;

/*在CommondLine下执行*/

exec INSERTAMOUNTTEST(1,2000);

2、更新数据

0

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

CREATE OR REPLACE PROCEDURE UPDATEAMOUNTTEST

(

WHERE_NUM IN VARCHAR2/*SQL语句条件值*/

)

IS

BEGIN

UPDATE tb1 SET col2=‘test2‘ where col1 like WHERE_NUM||‘%‘;

/*异常处理*/

EXCEPTION

WHEN OTHERS THEN

rollback;

END;

/*在CommondLine下执行*/

exec UPDATEAMOUNTTEST(‘11‘);

3、存储过程之间的调用
以一个查询更新为例子

C#

0

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

/*

查询更新存储过程,调用更新存储过程UPDATEAMOUNTTEST2

*/

CREATE OR REPLACE PROCEDURE SELECTUPDATETEST

(

tJStr IN CHAR

)

is

upStr CHAR(20);

begin

/*

查询出要更新的字段值

*/

select a.col2 into upStr from tb1 a where a.col1 = tJStr;

/*

调用更新存储过程

传入用于更新的两个参数

*/

UPDATEAMOUNTTEST2(‘11‘,upStr);

end SELECTUPDATETEST;

/*

更新用的存储过程,被SELECTUPDATETEST调用

*/

CREATE OR REPLACE PROCEDURE UPDATEAMOUNTTEST2

(

WHERE_NUM IN VARCHAR2,/*更新条件*/

SET_NAME IN VARCHAR2/*更新后的字段值*/

)

IS

BEGIN

UPDATE tb1 SET col2=SET_NAME where col1 like WHERE_NUM||‘%‘;

EXCEPTION

WHEN OTHERS THEN

rollback;

END;

时间: 2024-10-25 16:19:10

【转】几个常用的Oracle存储过程的相关文章

项目中oracle存储过程记录——常用语法备忘

项目中oracle存储过程记录--常用语法备忘 项目中需要写一个oracle存储过程,需求是收集一个复杂查询的内容(涉及到多张表),然后把符合条件的记录插入到目标表中.其中原表之一的日期字段是timestamp类型,目标表的字段是varchar2类型: 其中一些内容很常用,所以做下记录,供查找. 1.存储过程的格式 oracle存储过程和函数都可以实现,一般没有返回值,则采用存储过程,函数比sqlserver的功能强大.oracle变量定义最好加上前缀如V_,查询条件中变量名称和字段名称不能重复

Oracle存储过程的学习

存储过程创建语法: create or replace procedure 存储过程名(param1 in type,param2 out type) as 变量1 类型(值范围); 变量2 类型(值范围); Begin Select count(*) into 变量1 from 表A where列名=param1: If (判断条件) then Select 列名 into 变量2 from 表A where列名=param1: Dbms_output.Put_line('打印信息'); El

Oracle存储过程(转)

存储过程创建语法: create or replace procedure 存储过程名(param1 in type,param2 out type) as 变量1 类型(值范围); 变量2 类型(值范围); Begin Select count(*) into 变量1 from 表A where列名=param1: If (判断条件) then Select 列名 into 变量2 from 表A where列名=param1: Dbms_output.Put_line('打印信息'); El

[转]oracle存储过程、声明变量、for循环

oracle存储过程.声明变量.for循环 1.创建存储过程 create or replace procedure test(var_name_1 in type,var_name_2 out type) as --声明变量(变量名 变量类型) begin --存储过程的执行体 end test; 打印出输入的时间信息 E.g: create or replace procedure test(workDate in Date) is begin dbms_output.putline(&ap

Oracle存储过程基本语法介绍

Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE 是一个SQL语句通知Oracle数据库去创建一个叫做skeleton存储过程, 如果存在就覆盖它; 行2: IS关键词表明后面将跟随一个PL/SQL体. 行3: BEGIN关键词表明PL/SQL体的开始. 行4: NULL PL/SQL语句表明什么事都不做,这句不能删

Oracle 存储过程_(收集)

oracle 存储过程的基本语法 1.基本结构 CREATE OR REPLACE PROCEDURE 存储过程名字(    参数1 IN NUMBER,    参数2 IN NUMBER) IS变量1 INTEGER :=0;变量2 DATE;BEGIN END 存储过程名字 2.SELECT INTO STATEMENT  将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条  记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND)  例子:   BEG

Oracle存储过程基本语法 存储过程

Oracle存储过程基本语法 存储过程 1 CREATE OR REPLACE PROCEDURE 存储过程名 2 IS 3 BEGIN 4 NULL; 5 END; 行1: CREATE OR REPLACE PROCEDURE 是一个SQL语句通知Oracle数据库去创建一个叫做skeleton存储过程, 如果存在就覆盖它; 行2: IS关键词表明后面将跟随一个PL/SQL体. 行3: BEGIN关键词表明PL/SQL体的开始. 行4: NULL PL/SQL语句表明什么事都不做,这句不能删

Oracle存储过程基本语法

存储过程 1  CREATE OR REPLACE PROCEDURE 存储过程名 2  IS 3  BEGIN 4  NULL; 5  END; 行1: CREATE OR REPLACE PROCEDURE 是一个SQL语句通知Oracle数据库去创建一个叫做skeleton存储过程, 如果存在就覆盖它; 行2: IS关键词表明后面将跟随一个PL/SQL体. 行3: BEGIN关键词表明PL/SQL体的开始. 行4: NULL PL/SQL语句表明什么事都不做,这句不能删去,因为PL/SQL

oracle存储过程、声明变量、for循环|转|

oracle存储过程.声明变量.for循环 1.创建存储过程 create or replace procedure test(var_name_1 in type,var_name_2 out type) as --声明变量(变量名 变量类型) begin --存储过程的执行体 end test; 打印出输入的时间信息 E.g: create or replace procedure test(workDate in Date) is begin dbms_output.putline(&ap