Listen Software解决方案 “How To” 系列2:存储过程
MILY: Verdana; mso-bidi-font-size: 10.0pt; mso-bidi-font-family: 宋体; mso-font-kerning: 0pt">
参照:
参照定义和使用游标
参照定义和使用函数
存储过程
CREATE OR REPLACE PROCEDURE {procedure name}
( {argument} IN {datatype} ) IS v_variable {datatype}; --变量类型
VARCHAR(X); VARCHAR2(X); VARCHAR2; CHAR(X);NUMBER(P,S);
--P-数字的位数
--S-数字的精度
NUMBER(X); NUMBER; LONG; --容纳32,760字节数据
DOUBLE PRECISION; FLOAT; INT; REAL; DATE; RAW(X) --容纳32,760字节数据
LONG RAW; --容纳32,760字节数据
--注意数据库类型为LONG RAW
--容纳20亿字节数据
RECORD; TABLE; VARRAY;LOB;
CLOB;v_variable_c1 VARCHAR2(20);
--创建20个字符长的变量
v_variable_c2 CHAR(10);
--创建固定长度为10个字符的变量
- 最大长度255
v_variable_c3 VARCHAR2; --变量长度不能超过2000个字符
v_variable_n1 table_name.field_name%TYPE;
--定义参照方案中表字段类型的变量类型
v_variable_n2 NUMBER; v_variable_n3 NUMBER := 3; v_variable_n4 NUMBER(10); v_variable_n5 NUMBER(10,2); v_variable_n6 LONG; v_variable_n7 FLOAT; v_variable_n8 REAL;TYPE t_my_record IS RECORD
( v_variable1 VARCHAR2(8) ,v_variable2 NUMBER(10) ,v_variable3 DATE );my_record t_my_record;
TYPE t_my_table is TABLE OF VARCHAR2(10)
--与vb中的数据结构相似
INDEX BY BINARY_INTEGER;
my_table t_my_table;
BEGIN
--这儿插入代码
v_variable_c1 := 'Hello World';
v_variable_n2 :=10;--条件逻辑
IF v_variable_n2 = 1 THEN
v_variable_c2 := 'Exact Match'; ELSIF v_variable_n3 > 2 THEN v_variable_c2 := 'Greater Than Match'; ELSE v_variable_c3 := 'None of the Above'; END IF;my_record.v_variable1:='ABC';
my_record.v_variable2:=3; my_record.v_variable3:=TO_DATE('11-JAN-1999','DD-MON-YYYY');my_table(1)='A';
my_table(2)='B';/* v_variable_n2的值为10,因此第一个条件为false.
v_variable_n3初始为3,因此条件为true,
v_variable_c2的值就为'Greater Than Match'
循环 */
v_variable_n2:=0;
LOOP v_variable_n2:=v_variable_n2+1; EXIT WHEN v_variable_n2 > 10; END LOOP;v_variable_n2:=0;
WHILE v_variable_n2<10 LOOP v_variable_n2:=v_variable_n2+1; END LOOP;FOR v_variable_n2 in 1..10 LOOP
END LOOP;
END {procedure name};