oracle 三种复合类型变量分析

实际项目中,经常遇到的三种复合类型变量。结合部分项目实例做个整理,具体如下:

  1. 记录类型:记录类型可以包含一个或多个成员,而每个成员的类型可以不同,成员可以是标量类型。也可以引用其他的变量类型。这种类型的特点是比较适合处理查询语句中有多个列的情况,最常用的情况就如在调用某一张表中的一行记录。
  2. 索引表类型(关联数组):索引表类型和数组相似,他利用键值查找对应的值,这里的键值同真正数组的下标不同,索引表中下标允许使用字符串。数组的长度不是固定值,可以根据需要自动增长。其中的键值是整数或是字符串,其中的值就是普通的标量类型,也可以是记录类型。(下标从1开始)
  3. VARRAY 变长数组:变长数组的元素个数需要限制,他是一个存储有序元素的集合,数组的下标从1开始,适合较少数据时使用。
eg1:记录类型-
declare
 type pro_x is record
 (v_id product_info.id%type,
 v_name varchar2(10),
 v_price number(8,2));
 
 v_pro pro_x;//声明变量 v_pro,v_pro的数据类型是pro_x类型。
 
 begin
   select id,name,price into v_pro from product_info where id=‘11011211410086‘;
   dbms_output.put_line(‘id:‘||v_pro.v_id||‘,‘||‘name:‘||v_pro.v_name||‘,‘||‘price:‘||v_pro.v_price);
   end;
   
   记录类型声明方式:type type_name is record(field_name datatype[not null]{:=|default}expression) 说明:not null 可以约束记录成员非空。
   可以使用%rowtype进行代替,实现上述功能。即:
 declare
v_pro product_info%rowtype;
 begin
   select id,name,price into v_pro from product_info where id=‘11011211410086‘;
   dbms_output.put_line(‘id:‘||v_pro.id||‘,‘||‘name:‘||v_pro.name||‘,‘||‘price:‘||v_pro.price);
  end;
  eg2:索引表类型(关联数组)---身份证校验
  declare
  type TiArray is table of integer;
  type TcArray is table of varchar2(1);
  type id_emp is table of qlr_info%type
  index by binary_integer;
  rst id_emp;
  W TiArray;
  A TcArray;
  S integer;
  tab varchar2(200);
  zuihyw varchar2(1);
  jieguo number;
  shenfzh varchar2(20);
  cursor c is 
  select zjbh from qlr_info where length(zjbh)=18 and zjzl=‘居民身份证‘ and regexp_like(substr(zjbh,1,17),‘^[0-9]*$‘);//regexp_like(substr(zjbh,1,17),‘^[0-9]*$‘) 表示查找截取的前17为字符串为数字。^:匹配开始位置;$:匹配结束位置;*:匹配零次或多次。
 begin
 W:=TiArray(7,9,10,5,8,4,2,1,6,3,7,9,10,5,8,4,2);
 A:=TcArray(‘1‘,‘0‘,‘X‘,‘9‘,‘8‘,‘7‘,‘6‘,‘5‘,‘4‘,‘3‘,‘2‘);
for emc in c 
loop
S:=0;
shenfzh:=emp.zjbh;
for i in 1..17 loop
S:=S+to_number(substr(shenfzh,i,1)*W(i));
end loop;
jieguo:=S mod 11;
zuihyw:=A(jieguo+1);
zuihyw2:=substr(shenfzh,18,1);
if (zuihyw<>zuihyw2) then
dbms_output_line(‘证件编号:‘emp.zjbh||‘错误!‘)
end if;
end loop;
end;
eg2.1使用字符串为键值的索引表
declare
type pro is table of number(8) index by varchar2(20);
v_pro pro;
begin
v_pro(‘test‘):=253;
v_pro(‘test1‘):=256;
dbms_out.put_line(v_pro.first ||‘,‘||v_pro(v_pro.first));
end;
索引表类型声明:
type type_name is table of {column_type|variable_name%type|table_name%rowtype}[not null] index by {pls_integer|binary_integer|varchar2(v_size)}

eg3,变长数组
declare
type varr is  varray(10) of varchar2(10);//定义数组长度10
v_pro varr:=varr(‘1‘,‘2‘);//初始化了两个元素(最多可以初始化10个)
begin
v_pro(1):=‘haha‘;
v_pro(2):=‘ouou‘;
dbms_output.put_line(v_pro(1)||‘,‘||v_pro(2));
end;
变长数组声明:type type_name is {varray|varying array}(size_limit)of element_type[not null]

                                                                    2016.05.11
时间: 2024-08-04 21:29:55

oracle 三种复合类型变量分析的相关文章

qlserver、Mysql、Oracle三种数据库的优缺点总结

这篇文章主要介绍了sqlserver.Mysql.Oracle三种数据库的优缺点总结,需要的朋友可以参考下 一.sqlserver优点:易用性.适合分布式组织的可伸缩性.用于决策支持的数据仓库功能.与许多其他服务器软件紧密关联的集成性.良好的性价比等:为数据管理与分析带来了灵活性,允许单位在快速变化的环境中从容响应,从而获得竞争优势.从数据管理和分析角度看,将原始数据转化为商业智能和充分利用Web带来的机会非常重要.作为一个完备的数据库和数据分析包,SQLServer为快速开发新一代企业级商业应

Delphi中定义了四种布尔类型:Boolean,ByteBool,WordBool和LongBool。后面三种布尔类型是为了与其他语言兼容而引入的

bool是LongBool类型. Delphi中定义了四种布尔类型:Boolean,ByteBool,WordBool和LongBool.后面三种布尔类型是为了与其他语言兼容而引入的,一般情况下建议使用Boolean类型. 这四种类型的布尔值占用内存的数量如下: Boolean 1 Byte ByteBool 1 Byte WordBool 2 Bytes(1 Word) LongBool 4 Bytes(2 Words) 对于ByteBool,WordBool和LongBool三种类型True

固本培元之三:Convert、运算符、流程控制语句、ref/out/in三种参数类型

一.Convert类常用的类型转换方法Convert.ToInt32() 转换为整型(int)Convert.ToChar() 转换为字符型(char)Convert.ToString() 转换为字符串型(string)Convert.ToDateTime() 转换为日期型(datetime)Convert.ToDouble() 转换为双精度浮点型(double)Conert.ToSingle() 转换为单精度浮点型(float) 二.运算符算术运算符 + - * / %逻辑运算符 & | ^

java Data、String、Long三种日期类型之间的相互转换

java Data.String.Long三种日期类型之间的相互转换 // date类型转换为String类型 // formatType格式为yyyy-MM-dd HH:mm:ss//yyyy年MM月dd日 HH时mm分ss秒 // data Date类型的时间 public static String dateToString(Date data, String formatType) { return new SimpleDateFormat(formatType).format(data

xhtml三种元素类型

xhtml三种元素类型:块级元素/内联元素/可变元素 块级元素:独占一行.可自定义自己的宽度和高度.作为其他元素的容器,可容纳其他内联元素和块级元素,喻做一个盒子.内联元素:始终以行内逐个显示.不能设置宽高,宽高由内容支撑.可定义padding/margin/border/background.可变元素:根据上下文确定是块级元素还是内联元素.注:不同的元素类型之间可以通过display属性来实现转换. 举例:块级元素:div/h1/p/form/hr/ifrom/......内联元素:span/

mysql、sqlserver、oracle三种数据库维护索引、外键、字段语法总结

mysql.sqlserver.oracle三种数据库维护索引.外键.字段语法总结 1.     MYSQL数据库 1)    创建索引 CREATE INDEX index_name ON table_name(column_list) CREATE UNIQUE INDEX index_name ON table_name(column_list) 修改表的方式添加索引 ALTER TABLE table_name ADD INDEX index_name(column_list) ALTE

Linux三种进程类型

Linux操作系统包括三种不同类型的进程,每种进程都有自己的特点和属性. 1.  交互进程是由一个Shell启动的进程.交互进程既可以在前台运行,也可以在后台运行. 2.  批处理进程和终端没有联系,是一个进程序列. 3.  监控进程(也称系统守护进程)是Linux系统启动时运行的进程,并常驻后台.例如,httpd是著名的Apache服务器的监控进程. init是Linux系统操作中不可缺少的程序之一.所谓的init进程,它是一个由内核启动的用户级进程. 内核自行启动(已经被载入内存,开始运行,

Sort merge join、Nested loops、Hash join(三种连接类型)

目前为止,典型的连接类型有3种: Sort merge join(SMJ排序-合并连接): 首先生产driving table需要的数据,然后对这些数据按照连接操作关联列进行排序:然后生产probed table需要的数据,然后对这些数据按照与driving table对应的连接操作列进行排序:最后两边已经排序的行被放在一起执行合并操作.排序是一个费时.费资源的操作,特别对于大表.所以smj通常不是一个特别有效的连接方法,但是如果driving table和probed table都已经预先排序

关于云的三种服务类型

云计算包含三种不同服务类型:SaaS.PaaS和IaaS: 软件即服务 (Software as a Service, SaaS)指的是通过浏览器,以服务形式提供给用户应用程序.有些是由公有云提供商提供的商用SaaS应用,有的则是企业私有云上提供的商用及订制的 SaaS应用.甲骨文是SaaS提供商,可提供众多的SaaS应用软件,以及托管与被管理的应用软件. 平台即服务 (Platform as a Service, PaaS) 指的是以服务形式提供给开发人员应用程序开发及部署平台,让他们可利用此