欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

plsq程序设计--定义变量

程序员文章站 2022-03-03 23:52:13
...
[color=red][b]变量声明规则[/b][/color]
变量名称不能使用保留关键字,建议变量统一使用v_开头
第一个字符必须是字母
变量名最多包含30个字符
不要与数据库的表或者列同名
每行只能声明一个变量

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

[color=red][b]变量声明示例[/b][/color]

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;

[color=red]
[b]record-变量类型[/b][/color]


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;



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


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;

[color=red]
[b]复合类型table--数组[/b][/color]
定义方法:
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