189 8069 5689

oracle过程怎么写,oracle过程怎么执行

oracle中的存储过程怎么写

Oracle存储过程写法实例

站在用户的角度思考问题,与客户深入沟通,找到罗城网站设计与罗城网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站建设、网站设计、企业官网、英文网站、手机端网站、网站推广、域名申请网站空间、企业邮箱。业务覆盖罗城地区。

总结项目中写的存储过程例子:

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

1 CREATE OR REPLACE PROCEDURE 存储过程名

2 IS/AS

3 BEGIN

4 NULL;

5 EXCEIPTION;

6 END;

1、创建存储过程,后面可用is或者as:

create or replace procedure PRO_COMPLAIN_TEMPLATE as

2、定义变量,此处用到了%TYPE和%ROWTYPE,参考 /database/201211/168564.html ,另外定义了一个游标,TEM_INSTANCE TEMPLATE_CUR%ROWTYPE这个类型定义必须要在游标定义之后:

NEED_DO_FOR_ZL INTEGER;

CURRENT_MAX_ID MEMO_TEMPLET.TEMPLET_ID%TYPE;

CURSOR TEMPLATE_CUR IS SELECT TEMPLET_NAME, TEMPLET_CONTENT FROM SYS_COMPLAINT_TEMPLET;

TEM_INSTANCE TEMPLATE_CUR%ROWTYPE;

3、begin开始块:

begin

4、该插入语句使用了DBLINK,还有使用DBMS_OUTPUT.put_line('打印信息')进行信息输出:

insert into MEMO_TEMPLET (TEMPLET_ID, TEMPLET_CONTENT, TEMPLET_TYPE, TEMPLET_MEMO) (SELECT * FROM MEMO_TEMPLET@COMPANY);

SELECT COUNT(*) INTO NEED_DO_FOR_ZL FROM SYS_COMPLAINT_TEMPLET;

IF(NEED_DO_FOR_ZL 0) THEN

DBMS_OUTPUT.put_line('打印信息');

SELECT MAX(TEMPLET_ID)+1 INTO CURRENT_MAX_ID FROM MEMO_TEMPLET;

DBMS_OUTPUT.put_line('MEMO_TEMPLET最大ID' || CURRENT_MAX_ID);

FOR TEM_INSTANCE IN TEMPLATE_CUR LOOP

INSERT INTO MEMO_TEMPLET (TEMPLET_ID, TEMPLET_CONTENT,

TEMPLET_TYPE, TEMPLET_MEMO) VALUES (CURRENT_MAX_ID,

TEM_INSTANCE.TEMPLET_CONTENT, '7', NULL);

CURRENT_MAX_ID := CURRENT_MAX_ID + 1;

DBMS_OUTPUT.put_line(TEM_INSTANCE.TEMPLET_CONTENT);

END LOOP;

END IF;

COMMIT;

4、exception块,使用WHEN OTHERS THEN,其中用raise可显示错误信息:

exception

WHEN OTHERS THEN

DBMS_OUTPUT.put_line('sqlcode : ' ||sqlcode);

raise;

ROLLBACK;

IF TEMPLATE_CUR%ISOPEN THEN

CLOSE TEMPLATE_CUR;

END IF;

DBMS_OUTPUT.put_line('打印信息');

end;

注:关于游标的使用,如果像本例中使用for循环去遍历游标的话则不需要显式的去用open/close

cursor打开和关闭游标,此处会自己处理,如果使用fetch

into的话就需要显式开关游标,另外任意执行一个update操作,用隐式游标sql的属性%found,%notfound,%rowcount,%isopen观察update语句的执行情况,也可以使用来判断游标状态,如IF

TEMPLATE_CUR%ISOPEN THEN。

Oracle数据库的存储过程怎么写?

Oracle存储过程基本语法:

CREATE OR REPLACE PROCEDURE 存储过程名 

IS 

BEGIN 

NULL; 

END;

解释:

行1: 

CREATE OR REPLACE PROCEDURE 是一个SQL语句通知Oracle数据库去创建一个叫做skeleton存储过程, 如果存在就覆盖它; 

行2: 

IS关键词表明后面将跟随一个PL/SQL体。 

行3: 

BEGIN关键词表明PL/SQL体的开始。 

行4: 

NULL PL/SQL语句表明什么事都不做,这句不能删去,因为PL/SQL体中至少需要有一句; 

行5: 

END关键词表明PL/SQL体的结束。

oracle存储过程并且怎么写

存储过程(procedure):是一个命名了的语句块,可以有0个或多个参数

语法:

create or replace procedure HelloWorld

as

begin

dbms_output.put_line('HelloWorld');

end;

调用存储过程

* 命令调用 exec helloworld

* 语句块调用

begin

helloworld;

end;

/

DELETE:

create or replace procedure del_emp01

is

begin

delete from emp01 where empno=7369;

end;

exec del_emp01;

create or replace procedure del_emp01(v_empno in emp01.empno%type)

is

begin

delete from emp01 wherer empno=v_empno;

end;

exec del_emp01(7521);

INSERT

create or replace procedure ins_emp01

(v_empno emp01.empno%type,v_ename emp01.ename%type)

as

begin

insert into emp01(empno,ename) values(v_empno,v_ename);

end;

exec ins_emp01(1000,'李四');

UPDATE

create or replace procedure upd_emp01

(v_empno emp01.empno%type,v_ename emp01.ename%type)

as

begin

update emp01 set ename=v_ename where empno=v_empno;

end;

exec upd_emp01(1000,'张三');

SELECT

create or replace procedure sel_emp01

(v_empno emp01.empno%type,v_emp01_data out emp01%rowtype)

as

begin

select * into v_emp01_data from emp where empno=v_empno;

end;

带有输出参数的存储过程不能使用命令直接调用

只能由语句块或程序调用(JAVA) ****************************************************************

declare

v_emp_data emp01%rowtype;

begin

sel_emp01(7499,v_emp_data);

dbms_output.put_line(v_emp_data.ename||' '||v_emp_data.sal);

end;

调用:

declare

v_emp_data emp01%rowtype;

begin

sel_emp01(7499,v_emp_data);

dbms_output.put_line(v_emp_data.ename||' '||v_emp_data.sal);

end;

使用scott用户登录

统计某个部门的员工的工资总和,员工的人数,平均工资,创建存储过程

create or replace procedure deptcount

(v_deptno emp.deptno%type,v_sal_sum out number,v_recordes out number,v_avg_sal out number,errorMsg out varchar2)

is

begin

select sum(sal) into v_sal_sum from emp group by deptno having deptno=v_deptno;

select count(*) into v_recordes from emp group by deptno having deptno=v_deptno;

select avg(sal) into v_avg_sal from emp group by deptno having deptno=v_deptno;

exception

when no_data_found then

errorMsg:='没有该部门';

end;

调用:

declare

v_sal_sum number;

v_recordes number;

v_avg_sal number(8,2);

v_errormsg varchar2(20);

begin

deptcount(90,v_sal_sum,v_recordes,v_avg_sal,v_errormsg);

dbms_output.put_line(v_sal_sum||' '||v_recordes||' '||v_avg_sal);

dbms_output.put_line(v_errormsg);

end;

//输出参数

create or replace procedure my_pro(v_num in number,v_result out number)

is

v_temp number;

begin

v_temp:=0;

for i in 1..v_num

loop

v_temp:=v_temp+i;

end loop;

v_result:=v_temp;

end;

declare

v_recieve number;

begin

my_pro(100,v_recieve);

dbms_output.put_line(v_recieve);

end;

//既是输入参数又是输出参数

create or replace procedure my_pro1(v_i in out number)

is

v_j number;

begin

v_j:=30;

v_i:=v_i*v_j;

end;

declare

v_t number;

begin

v_t:=20;

my_pro1(v_t);

dbms_output.put_line(v_t);

end;


名称栏目:oracle过程怎么写,oracle过程怎么执行
网站网址:http://jkwzsj.com/article/hcepso.html

其他资讯