1、oracle存储过程的基本语法1.基本结构 CREATEORREPLACEPROCEDURE存储过程名字( 参数1INNUMBER, 参数2INNUMBER)IS变量1INTEGER:=0;变量2DATE;BEGINEND存储过程名字2.SELECTINTOSTATEMENT 将select查询的结果存入到变量中,可以同时将多个列存储多个变量中,必须有一条 记录,否则抛出异常(如果没有记录抛出NO_DATA_FOUND) 例子: BEGIN SELECTcol1,col2into变量1,变量2FROMtypestructwherexxx; EXCEPTION
2、WHENNO_DATA_FOUNDTHEN xxxx; END; ...3.IF判断 IFV_TEST=1THEN BEGIN dosomething END; ENDIF;4.while循环 WHILEV_TEST=1LOOP BEGIN XXXX END; ENDLOOP;5.变量赋值 V_TEST:=123;6.用forin使用cursor ... IS CURSORcurISSELECT*FROMxxx; BEGIN FORcur_resultincurLOOP BEGIN V_SUM:=cur_result.列名1+cur_r
4、关于oracle存储过程的若干问题备忘1.在oracle中,数据表别名不能加as,如:select a.appname from appinfo a;-- 正确select a.appname from appinfo as a;-- 错误 也许,是怕和oracle中的存储过程中的关键字as冲突的问题吧2.在存储过程中,select某一字段时,后面必须紧跟into,如果select整个记录,利用游标的话就另当别论了。 select af.keynode into kn from APPFOUNDATION af where af.appid=aid and af.fo
5、undationid=fid;-- 有into,正确编译 select af.keynode from APPFOUNDATION af where af.appid=aid and af.foundationid=fid;-- 没有into,编译报错s,提示:Compilation Error: PLS-00428: an INTO clause is expected in this SELECT statement3.在利用select...into...语法时,必须先确保数据库中有该条记录,否则会报出"nodatafound"异常。或者exceptionw
6、henno_data_foundthennull; 可以在该语法之前,先利用selectcount(*)from 查看数据库中是否存在该记录,如果存在,再利用select...into...4.在存储过程中,别名不能和字段名称相同,否则虽然编译可以通过,但在运行阶段会报错 select keynode into kn from APPFOUNDATION where appid=aid and foundationid=fid;-- 正确运行select af.keynode into kn from APPFOUNDATION af where af.appid=a
7、ppid and af.foundationid=foundationid;-- 运行阶段报错,提示ORA-01422:exact fetch returns more than requested number of rows5.在存储过程中,关于出现null的问题假设有一个表A,定义如下:create table A(id varchar2(50) primary key not null,vcount number(8) not null,bid varchar2(50) not null -- 外键 );如果在存储过程中,使用如下