文档章节

PLSQL集合类型

爱潜水的小八
 爱潜水的小八
发布于 2017/02/17 11:55
字数 764
阅读 4
收藏 0

PLSQL集合类型

 

--联合数组(索引表)

/*

用于存储某个数据类型的数据集合类型 。通过索引获得联合数组中得值

如下例子:

*/

DECLARE 

 CURSOR cur_chars IS SELECT chars FROM a;--声明游标

 TYPE str_type IS TABLE OF a.chars%TYPE--声明联合数组

 INDEX BY BINARY_INTEGER; --声明联合数组的索引

 strs str_type;--声明str_type 的联合数组strs

 counts INTEGER := 0;

BEGIN 

  FOR cur_chars_rec IN cur_chars LOOP

    counts := counts + 1;

    strs(counts) := cur_chars_rec.chars;

    dbms_output.put_line('counts('||counts||'):'||strs(counts));

  END LOOP;

END;

这个联合索引类型其实就是表数据的索引,定义游标然后把遍历到的结果存放在联合数组中,就相当于程序的基本数据类型数组

1.声明游标用来遍历表数据2.声明联合数组用来存储游标遍历的数据集3.声明索引

4.定义联合数组 联合数组名称 联合数组type

 

strs(counts) := cur_chars_rec.chars;  联合数组赋值命令

 

 

--嵌套表

/*

plsql表类型之一,他与联合数组具有相同的结构,都是使用下标访问数组

主要区别在于,嵌套表可以存储在数据库表的列中,而联合数组不行

*/

DECLARE

 CURSOR my_cursor IS SELECT chars FROM a WHERE NUM='ww' ;--定义游标

 TYPE table_type IS TABLE OF a.chars%TYPE;--声明表类型

 table_name table_type:=table_type();--定义并初始化嵌套表

 counts INTEGER := 1;

BEGIN

  FOR my_cursor_rec IN my_cursor LOOP

    counts := counts;

    table_name.extend;--表做成可扩展的***

    table_name(counts):=my_cursor_rec.chars;

    dbms_output.put_line('counts'||counts||' := '||table_name(counts));

  END LOOP;

END;

--创建变长数组

DECLARE

 TYPE varray_type IS ARRAY(10) OF NUMBER(6);

 varray_name varray_type := varray_type(); --变长数组同嵌套表相同都需要初始化收集

 counts INTEGER := 0;

BEGIN

  FOR i IN 1..5 LOOP

    counts := counts + 1;

    varray_name.extend;

    varray_name(counts) := i;--这个都是相同的使用下标

    dbms_output.put_line('counts('||counts||'):='||i);

  END LOOP;

END;

 

  varray_name.extend; 的使用超过范围的时候需要使用扩展

  集合函数的使用count 数量 first 第一个 last 最后一个

  Varrary_array.count Varrary_array.first  Varrary_array.last

  Varrary_array.trim(4) 从后往前删除4个数组元素

 

多层集合 集合作为集合的元素

变长数组为例 就相当于数据的嵌套

--多层集合(数组的嵌套)

DECLARE

 TYPE var_type1 IS VARRAY(5) OF INTEGER;--声明变长数组

 TYPE var_type2 IS VARRAY(3) OF var_type1;--声明多层集合,集合元素类型为var_type1

 varray_integer var_type1 := var_type1(1,2,3,4,5);--集合给初始值

 varray_multi var_type2 := var_type2(varray_integer);

 

BEGIN

  FOR i IN 1..5 LOOP

    dbms_output.put_line('varray_integer('||i||'):='||varray_integer(i));

  END LOOP;

  

  varray_multi.extend;

  varray_multi(2) := var_type1(6,7,8,9,10);

  

  varray_multi.extend;

  varray_multi(3) := var_type1(5,4,3,2,1);

  

  FOR i IN 1..3 LOOP

   FOR j IN 1..5 LOOP

         dbms_output.put_line('varray_multi['||i||']'||'['||j||']=='||varray_multi(i)(j));

   END LOOP;

  END LOOP;

END;

 

 

--集合的方法

DELETE --删除集合元素

EXTEND --为集合增加元素空间,实现空间的扩展以填充新元素。

COUNT --集合元素中的数量

EXISTS --如果指定的元素在集合中存在,则返回true

DELETE --删除指定集合位置的元素

FIRST AND  LAST --集合中的第一个和最后一个元素

PRIOR AND NEXT --返回集合指定位置的前一个和后一个元素

TRIM --从集合尾部删除元素

LIMIT --返回集合允许元素的最大数量

© 著作权归作者所有

共有 人打赏支持
爱潜水的小八
粉丝 4
博文 14
码字总数 9447
作品 0
大连
程序员
私信 提问
PLSQL集合笔记

针对多行单列的数据处理,用之前的标量变量肯定不行,这里引入一个新的数据类型复合数据类型。 这个复合类型类似于语言的数组struct[i],包括索引表,嵌套表,边长数组三种类型, 记住记录是...

aklaus
2017/08/04
0
0
Oracle之FORALL与BULK COLLECT简介

在上篇文章Oracle大数据的导入与更新方案中介绍了导入超大数据量的操作,而要批量更新超大数据量的操作时就需要用到本文所要介绍的FORALL与BULK COLLECT语句。 1 PL/SQL块的执行过程 当PL/SQ...

landy8530
03/17
0
0
【入门】plsql几种集合类型的区别

plsql中有3中集合类型。分别是可变长数组,嵌套表,关联表(索引表)。 简单的说下它们之间的区别。 1.type tnum is varray(100) of number(5); vnum tnum := tnum(1,2,3,4); 2.type tnum i...

shiwb
2013/04/23
0
0
Oracle PLSQL的集合类型

转载:http://www.cnblogs.com/gkl0818/archive/2009/02/25/1397769.html Oracle collections 一、Types of Collections 1、Associative arrays 数组 它是同种类型的一维、无边界的稀疏集合,......

晨曦之光
2012/04/25
1K
0
Oracle 中的动态 SQL

动态SQL也被称作通用的或集合的SQL。它与其它任何在运行时生成的动态代码类似;它基于运行时的数值与变量而不是明确字符串。 当我们写了一些代码又希望改变选择的列,以及想基于我们的商务需...

等PM
2013/03/24
517
0

没有更多内容

加载失败,请刷新页面

加载更多

Angularjs实现控制器之间通信方式示例

利用angularjs开发项目中,控制器之间的通信,比如参数的传递,数据的传递,都是比较常见的。控制器之间的通信,显得尤为重要。常见的方式有如下两种:一、angular服务的方式;二、基于事件广...

前端攻城老湿
16分钟前
0
0
xshell使用xftp传输文件

12月11日任务 15.4 xshell使用xftp传输文件 15.5 使用pure-ftpd搭建ftp服务 1.xshell使用xftp传输文件 示例一:xshell使用sftp传输文件 新建一个会话 定义为sftp 连接登入 可以get文件,下载...

hhpuppy
19分钟前
1
0
深入解析Vuex实战总结

这篇文章主要介绍了Vuex的初探与实战小结,写的十分的全面细致,具有一定的参考价值,对此有需要的朋友可以参考学习下。如有不足之处,欢迎批评指正。 1.背景 最近在做一个单页面的管理后台项...

前端攻城小牛
19分钟前
1
0
eslint rules 规则

'rules': { "comma-dangle": ["error", "never"], //是否允许对象中出现结尾逗号 "no-cond-assign": 2, //条件语句的条件中不允许出现赋值运算符 "no-console": 2, //不允许出现console语句 ...

agenyun
今天
2
0
类型判断时instanceof和equals的不同用法

接口设计时为了避免序列化的麻烦,将接口定义为参数为map<String,String>类型的接口,但是现在调用时需要转换当前的实体Bean为Map,接口接收方再把Map转换为另一个Bean实体。过程中的需要对类...

wangtx
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部