oracle 声明复合类型,oracle中的复合数据类型

1)显示定义记录类型;

declare

--显示定义一个record类型myrec

type myrec is RECORD (

combine_no VARCHAR2(10),

department_code VARCHAR2(11)

);

-- 声明一个myrec类型的变量rcd;

rcd myrec;

begin

select nr.combine_no,nr.department_code  into rcd from rate_combine_nr nr where nr.combine_no=‘G600000001‘;

dbms_output.put_line(rcd.combine_no||‘-‘||rcd.department_code);

end;

2)有一些PL/SQL指令在使用隐式定义记录时没有使用%ROWTYPE属性,比如游标FOR循环;

declare

cursor mycur is

select * from rate_combine_nr nr where rownum <10;

rcd  mycur%rowtype; --这个可以省略;

begin

for rcd in mycur loop

dbms_output.put_line(rcd.combine_no||‘-‘||rcd.department_code);

end loop;

end;

3)PL/SQL有三种类型的集合

VARRAY集合中的元素的数量是有限,Index_by和嵌套表则是没有限制的

.)Index_by表

Index_by表集合的定义语法如下:

. TYPE type_name IS TABLE OF element_type [NOT NULL] INDEX BY BINARY_INTERGET;

. 这里面重要的关键字是INDEX BY BINARY_INTERGET,没有这个关键字,那么集合将是一个嵌套表;

. 一旦定义了index_by表,就可以向创建其他变量那样创建index_by表的变量;

.) 嵌套表

嵌套表非常类似于Index_by表,创建的语法也非常相似。使用TYPE语句,只是没有INDEX BY BINARY_INTEGER子串

TYPE type_name IS TABLE OF element_type [NOT NULL] ;

.)VARRAY

VARRAY或数据变量都有元素的限制。想起他集合一样VARRAY定义仍然使用TYPE语句,但关键字VARRAY或VARRYING

ARRAY告诉ORACLE这  是一个VARRAY集合。

TYPE type_name IS VARRAY (max_size) OF element_type [NOT NULL];

. 下标的取值从1开始;

原文:http://6817977.blog.51cto.com/6807977/1597122

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值