plsq程序设计--定义变量

[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;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值