温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

oracle中的复合数据类型

发布时间:2020-07-30 07:32:40 来源:网络 阅读:593 作者:lxg290 栏目:关系型数据库

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开始;


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI