牛骨文教育服务平台(让学习变的简单)
博文笔记

Oracle type (自定义类型的使用)

创建时间:2014-11-21 投稿人: 浏览次数:2520

oracle - type

 

type定义:

oracle中自定义数据类型
oracle中有基本的数据类型,如number,varchar2,date,numeric,float....但有时候我们需要特殊的格式,

如将name定义为(firstname,lastname)的形式,我们想把这个作为一个表的一列看待,这时候就要我们自己定义一个数据类型
格式 :create or replace type type_name as object(parameter1 varchar2(20),parameter2 varchar2(30));
这样子定义之后我们就能像使用基本类型一样使用自定义类型去建表:
如:
create or replace type name_format as object(firstname varchar2(20),lastname varchar2(30));
定义了类型之后,我们就可以将它当作普通的基本类型用了,建表,写function等等,如用自定义数据类型建表:
create table testtable(id number primary key,name name_format);

插入数据时,构造我们的这个自定义列时,就像构造对象一样,如上面的表插入数据的sql语句如下:
insert into testtable values(1,name_format("hust","lkq"));
查询自定义列的某个值可以用.来访问,如上面我要查询testtable表中name列的firstname的值可以按照如下查询:
select t.name.firstname from testtable t;

自定义数据类型也可以是集合
例如:create or replace type numers_set as array(10) of number;
这就表示创建了一个包含10个number数据的自定义类型,
注:这里的集合里面的基本元素也可以是你自定义的类型,也就是说支持嵌套定义
create or replace type name_list as array(10) of name_format:(此处的name_format就是我们在上面定义的一个自定义类型

 

 将表中查出来的值赋值给ob:

复制代码
select rec_planratemain(planrgroupmainid,
                                pl.productid,
                                planrateversion,
                                pl.createuserid,
                                pl.createdate,
                                pl.updateuserid,
                                pl.updatedate,
                                ratedatetype,
                                startdate,
                                enddate,
                                p.branchid,
                                channeltype)
          into g_rec_planmainrate -- 实例化后的名字
          from planrgroupmain pl,productbranch_property p
         where pl.productid = "PROG0000003001024"
         and p.productid = pl.productid 
              --and startdate <= p_date
              --and ENDDATE >= p_date
           and p.branchid = "BRA0000000000011"
           and rownum < 2;
复制代码

 

OB:

 

+ View Code

 NT:

 

+ View Code

 

调用:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 function getagentbroker(p_branchid  IN VARCHAR2,                           p_month     in VARCHAR2,                           p_agentcode in varchar2,                           p_type        in varchar2) return nt_test is     v_Count   SMALLINT DEFAULT 0;     v_NT_test NT_test;     v_num     smallint default 10;   begin        if p_type = "B"  then         v_num  := 0;      end if;         v_NT_test := NEW nt_test();         for c_ag in (select a.agentid,                         a.recommendagentid,                         getagentstatus(a.agentstatus) agentstatus,                         a.agentcode,                         a.agentname,                         a.agentlevelcode,                         a.hiredate                    from agenthis a                   where a.bizyearmonth = p_month                     and a.agentstatus = "AGENTSTATUS_09"                     and a.branchid = p_branchid                     and (a.agentcode =p_agentcode or p_agentcode is null)                     and (rownum <= v_num or v_num = 0)                                     ) loop      
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。