plsq程序设计--定义变量

变量声明规则
变量名称不能使用保留关键字,建议变量统一使用v_开头
第一个字符必须是字母
变量名最多包含30个字符
不要与数据库的表或者列同名
每行只能声明一个变量

常用变量类型
binary_integer:整数,用来计数
number:数字类型
char:定长字符串
varchar2:变长字符
date:日期
long:长字符串,最长2g
boolean:布尔类型,可以取值:true、false、null

变量声明示例
declare
    v_temp number(1);
    v_count binary_integer := 0;
    v_sal number(7,2) := 4000.00;
    v_date date := sysdate;
    v_pi constant number(3,2) := 3.14;
    v_valid boolean := false;
-- 可以在声明变量时,指定非空或其他属性
    v_name varchar2(20) not null := 'MyName';
/* 
 %type属性:根据emp表的empno字段来规定v_empno变量的长度,
并且v_empno的长度自动随着emp表的empno字段的长度改变而改变
*/
    v_empno emp.empno%type;
    v_empno2 v_empno%type;
begin
-- dbms_output.put_line不可以输出boolean类型的变量
    dbms_output.put_line('v_date value:' || to_char(v_date,'yyyy-mm-dd'));

end;


record-变量类型


declare
-- record-变量类型,有点类似于java的类的概念
    type type_record_dept is record
    (
        deptno dept.deptno%type,
        dname dept.dname%type,
        loc dept.loc%type
    );
    -- 声明一个"type_record_dept变量类型"的变量v_temp
    v_temp type_record_dept;
begin
    v_temp.deptno := 50;
    v_temp.dname := '张三';
    v_temp.loc := '山东';
    dbms_output.put_line(v_temp.deptno || ' ' || v_temp.dname);
end;




使用%rowtype声明record变量
使用%rowtype后边加上表明,那么该变量就会自动根据表的列定义好n个内部变量,
并且内部变量的属性,数量会根据表的改变自动改变。


declare
--将v_type的内部变量按照dept表的列自动建立
    v_type dept%rowtype;
begin
    v_temp.deptno := 50;
    v_temp.loc := '北京';
    v_temp.dname := '王五';
    dbms_output.put_line(v_temp.deptno || ' ' || v_temp.dname);
end;    


复合类型table--数组

定义方法:
type 变量名称(v_table_x表_x字段) is table of 类型 index by binary_integer;
示例:
declare
--定义一个type_table_emp名称的table类型,该变量类型为emp表empno字段类型,使用binary_integer作为下标
  type type_table_emp_empno is table of emp.empno%type index by binary_integer;
--定义一个type_table_emp_empno类型的变量v_empnos
  v_empnos type_table_emp_empno;
begin
  v_empnos(0) := 7369;
  v_empnos(2) := 7839;
--下标可以使用负数
  v_empnos(-1) := 9999;
  dbms_output.put_line(v_empnos(-1));
end; 

你可能感兴趣的:(sql)