1)显示定义记录类型; declare --显示定义一个record类型myrec type myrec is RECORD
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开始;
--结束END--
本文标题: oracle中的复合数据类型
本文链接: https://www.lsjlt.com/news/44274.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-08
2024-05-08
2024-05-08
2024-05-08
2024-05-08
2024-05-08
2024-05-08
2024-05-08
2024-05-08
2024-05-08
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0