当前位置: 首页 > 编程日记 > 正文

PL/SQL集合类型的整理学习

http://log-cd.iteye.com/blog/521177

PL/SQL集合类型是类似于高级语言数组的一种复合数据类型,集合类型包括索引表(PL/SQL表)、嵌套表(Nested Table)和变长数组(VARRAY)三种类型。
<一>、索引表
    索引表也称为PL/SQL表,它是Oracle早期版本用于处理PL/SQL数组的数据类型。索引表的元素个数没有限制,并且下标可以为负值。注意,索引表只能作为PL/SQL复合数据类型使用,而不能作为表列的数据类型使用。
    语法:

Sql代码 收藏代码

  1. TYPE type_name IS TABLE OF element_type
  2. [NOT NULL] INDEX BY key_type;
  3. identifier type_name;

说明:从Oracle9i开始,索引表下标不仅允许使用数据类型BINARY_INTEGER、PLS_INTEGER,而且允许使用数据类型VARCHAR2。
    示例一:

Sql代码 收藏代码

  1. declare
  2. type xm_table_type is table of drv_admin.drv_temp.xm%type
  3. index by binary_integer;
  4. xm_talbe xm_table_type;
  5. begin
  6. select xm into xm_talbe(-1) from drv_admin.drv_temp
  7. where lsh='&lsh';
  8. dbms_output.put_line('姓名:'||xm_talbe(-1));
  9. end;

示例二:

Sql代码 收藏代码

  1. declare
  2. type area_table_type is table of number
  3. index by varchar2(10);
  4. area_table area_table_type;
  5. begin
  6. area_table('北京'):=1;
  7. area_table('上海'):=2;
  8. area_table('天津'):=3;
  9. dbms_output.put_line('第一个元素:'||area_table.first);--第一个元素下标
  10. dbms_output.put_line('最后一个元素:'||area_table.last);--最后一个元素下标
  11. end;

<二>、嵌套表
   嵌套表的元素下标从1开始,并且元素个数没有限制。嵌套表数组元素值可以是稀疏的。
   注意:索引表类型不能作为表列的数据类型使用,但嵌套表类型可以作为表列的数据类型。
   语法:

Sql代码 收藏代码

  1. type type_name is table of element_type;
  2. identifier type_name;

1.在PL/SQL块中使用嵌套表

Sql代码 收藏代码

  1. declare
  2. type xm_table_type is table of drv_admin.drv_temp.xm%type;
  3. xm_table xm_table_type;
  4. begin
  5. xm_table:=xm_table_type(' ',' ',' ');--这里必须使用构造方法初始化嵌套表变量。
  6. select xm into xm_table(2) from drv_admin.drv_temp
  7. where lsh='&lsh';
  8. dbms_output.put_line('姓名:'||xm_table(2));
  9. end;

2.在表列中使用嵌套表
  在表列中使用嵌套表类型,必须首先使用CREATE TYPE命令建立嵌套表类型。另外注意,必须要为嵌套表列指定专门的存储表。
  示例如下:

Sql代码 收藏代码

  1. create type phone_type is table of varchar2(20);
  2. /
  3. create table employee(
  4. id number(4),name varchar2(10),sal number(6,2),phone phone_type
  5. )nested table phone store as phone_table;

(1)在嵌套表中插入数据
  当定义嵌套表类型时,Oracle自动为该类型生成相应的构造方法。当为嵌套表列插入数据时,需要使用嵌套表的构造方法。

Sql代码 收藏代码

  1. BEGIN
  2. INSERT INTO employee VALUES(1,'TOM',800,
  3. phone_type('028-90909800','13913001300')
  4. );
  5. END;
  6. /

(2)在嵌套表中检索数据
   需要定义嵌套表类型的变量接收其数据。

Sql代码 收藏代码

  1. DECLARE
  2. phone_table phone_type;
  3. BEGIN
  4. SELECT phone INTO phone_table
  5. FROM employee WHERE id=1;
  6. FOR i IN 1..phone_table.COUNT LOOP
  7. dbms_output.put_line('电话号码:'||phone_table(i));
  8. END LOOP;
  9. END;

(3)在嵌套表中更新数据
  首先需要定义嵌套表变量,并使用构造方法初始化该变量,然后才可在执行部分使用UPDATE语句更新其数据。

Sql代码 收藏代码

  1. DECLARE
  2. phone_table phone_type:=phone_type('028-10001000','139800900100');
  3. BEGIN
  4. UPDATE employee SET phone=phone_table
  5. WHERE id=1;
  6. END;
  7. /

<三>、变长数组(VARRAY)
   可以作为表列的数据类型使用。其元素下标以1开始,并且元素的最大个数是有限制的。
   语法:

Sql代码 收藏代码

  1. TYPE type_name IS VARRAY(size_limit) OF element_type [NOT NULL];
  2. Identifier type_name;

注意,当使用VARRAY元素时,必须要使用其构造方法初始化VARRAY元素。
1.在PL/SQL块中使用VARRAY

Sql代码 收藏代码

  1. DECLARE
  2. TYPE xm_table_type IS VARRAY(20) OF drv_admin.drv_temp.xm%TYPE;
  3. xm_table xm_table_type:=xm_table_type(' ');
  4. BEGIN
  5. SELECT xm INTO xm_table(1) FROM drv_admin.drv_temp
  6. WHERE lsh='&lsh';
  7. dbms_output.put_line('姓名:'||xm_table(1));
  8. END;
  9. /

2.在表列中使用VARRAY

Sql代码 收藏代码

  1. CREATE TYPE phone_type IS VARRAY(20) OF VARCHAR2(20);
  2. /
  3. CREATE TABLE employee(
  4. id NUMBER(4), name VARCHAR2(10), sal NUMBER(6,2), phone phone_type
  5. );

注意,嵌套表列的元素个数没有限制,而VARRAY列的元素个数是有限制的。
<四>、PL/SQL记录表
  为了在PL/SQL块中处理多行多列数据,开发人员可以使用PL/SQL记录表。

Sql代码 收藏代码

  1. DECLARE
  2. TYPE tmp_table_type IS TABLE OF drv_admin.drv_temp%ROWTYPE
  3. INDEX BY BINARY_INTEGER;
  4. tmp_table tmp_table_type;
  5. BEGIN
  6. SELECT * INTO tmp_table(1) FROM drv_admin.drv_temp
  7. WHERE lsh='&lsh';
  8. dbms_output.put_line('姓名:'||tmp_table(1).xm);
  9. dbms_output.put_line('备注:'||tmp_table(1).bz);
  10. END;
  11. /

<五>、集合方法
   语法:

Sql代码 收藏代码

  1. collection_name.method_name[(parameters)]

注意,集合方法只能在PL/SQL语句中使用,而不能在SQL语句中调用。另外集全方法EXTEND和TRIM只适用于嵌套表和VARRAY,而不适用于索引表。
1.EXISTS:确定集合元素是否存在。

Sql代码 收藏代码

  1. IF xm_table.EXISTS(1) THEN
  2. xm_table(1):='Tom';
  3. ELSE
  4. dbms_output.put_line('必须初始化集合元素');
  5. END IF;

2.COUNT:返回当前集合变量中的无素总个数。
3.LIMIT:返回集合元素的最大个数。VARRAY返回所允许的最大元素个数,其它返回NULL。
4.FIRST和LAST:返回集合变量第一个和最后一个元素的下标。
5.PRIOR和NEXT:返回当前元素的前一个和后一下元素下标。
6.EXTEND
  用于扩展集合变量的尺寸,并为它们增加元素。注意,该方法只适用于嵌套表和VARRAY。EXTEND用于为集合变量添加一个null元素,EXTEND(n)用于为集合变量添加n个null元素,EXTEND(N,I)用于为集合变量添加n个元素(元素值与第i个元素相同)。
7.TRIM
  用于从集合尾部删除元素,它有TRIM和TRIM(n)两种调用格式。TRIM用于从集合尾部删除一个元素;TRIM(n)则用于从集合尾部删除n个元素。注意,该方法只适用于嵌套格和VARRAY。
8.DELETE
  用于删除元素,但该方法只适用于嵌套格和索引表,而不适用于VARRAY。DELETE用于删除集合变量的所有元素;DELETE(n)用于删除集合变量的第n个元素;而DELETE(m,n)则用于删除集合变量中从m到n之间的所有元素。



本文转自hcy's workbench博客园博客,原文链接:http://www.cnblogs.com/alterhu/archive/2012/03/22/2411821.html,如需转载请自行联系原作者。

相关文章:

多条件组合查询+分页

比较麻烦&#xff0c;把他记录下来。前台UI&#xff1a;实现的类代码:程序代码/// <summary>/// 多条件组合查询/// </summary>/// <param name"suppliercode">供应商代码</param>/// <param name"materialcode">物料代码&l…

Matlab与线性代数 -- 矩阵的重组1

本图文介绍了矩阵重组的第一种情况用新的行或列取代原有矩阵的行或列。

工作中感受到的消息中间件在分布式系统中的使用场景

经历 以前在qunar实习&#xff0c;第一次接触消息中间件&#xff0c;那时候概念还不清楚&#xff0c;朦朦胧胧有个初步认识&#xff0c;现在正式工作了&#xff0c;又一次接触了消息中间件&#xff0c;初步总结几种场景。 场景 1.分布式系统中&#xff0c;不同系统之间传递消…

sql server 2005分页存储过程和sql server 2000分页存储过程(摘)

USE[svnhost]GO/****** 对象: StoredProcedure [dbo].[up_Page2005] 脚本日期: 05/21/2008 11:27:05 ******/SETANSI_NULLS ONGOSETQUOTED_IDENTIFIER ONGOCREATEproc[dbo].[up_Page2005]TableNamevarchar(50), --表名Fieldsvarchar(5000) *, --字段名(全部字段为…

topcoder srm 691 div1 -3

1、给定一个$n$个顶点$n$个边的图&#xff0c;边是$(i,a_{i})$&#xff0c;顶点编号$[0,n-1]$。增加一个顶点$n$,现在选出一个顶点集$M$,对于任意的在$M$中 的顶点$x$&#xff0c;去掉边$(x,a_{x})$&#xff0c;增加边$(x,n)$。最后使得顶点0和1相连。有多少种$M$? 思路&#…

Matlab与线性代数 -- 矩阵的重组2

本图文详细介绍了矩阵重组的第二种情况任意两行或两列进行对换。

mac通过tree源码编译安装tree

通过tree源码编译安装 下载源码&#xff1a;curl -O ftp://mama.indstate.edu/linux/tree/tree-1.6.0.tgz 解压源码&#xff1a;tar xzvf tree-1.6.0.tgz 修改Makefile文件&#xff1a; tree默认的是linux的编译环境&#xff0c;因此移植到mac里面需要注释掉linux的编译选项&am…

java IO流文件的读写具体实例

IO流的分类&#xff1a;1、根据流的数据对象来分&#xff1a;高端流&#xff1a;所有的内存中的流都是高端流&#xff0c;比如&#xff1a;InputStreamReader 低端流&#xff1a;所有的外界设备中的流都是低端流&#xff0c;比如InputStream&#xff0c;OutputStream 如何区分…

Matlab与线性代数 -- 矩阵的重组3

本图文详细介绍了矩阵重组的第三种情况&#xff0c;从矩阵中选取子矩阵。

ASP.NET小收集:IFrame使用

使用Iframe制作一个固定框架&#xff0c;很方便与象后台网站之类的页面1<html xmlns"http://www.w3.org/1999/xhtml">2<head runat"server">3<title>后台</title>4</head>5<frameset cols"170,*"framespacing&…

linux mac中实现类似secureCRT的clone session

在你的登录账户下的.ssh文件夹新建一个文件&#xff1a;config. cd ~/.ssh vi config config的文件中&#xff0c;内容为&#xff1a; host * ControlMaster auto ControlPath ~/.ssh/master-%r%h:%p 重新打开终端&#xff0c;第一次&#xff0c;你还是需要输入密码&#xff0c…

C#动态加载DLL(转)

利用反射进行动态加载和调用.Assembly assAssembly.LoadFrom(DllPath); //利用dll的路径加载加载dll后,需要使用dll中某类.Type typeass.GetType(“TypeName”);//利用类型的命名空间和名称获得类型需要实例化类型,才可以使用,参数可以人为的指定,也可以无参数,静态实例可以省略…

mysql高可用之MMM

博主QQ&#xff1a;819594300博客地址&#xff1a;http://zpf666.blog.51cto.com/有什么疑问的朋友可以联系博主&#xff0c;博主会帮你们解答&#xff0c;谢谢支持&#xff01;一、MMM简介&#xff1a;MMM即Multi-MasterReplication Manager for MySQL:mysql多主复制管理器。M…

Matlab与线性代数 -- 矩阵的重组4

本图文详细描述了矩阵重组的第四种情况&#xff0c;将矩阵改写成行向量或者列向量。

利用spring aop统一处理异常和打日志

利用spring aop统一处理异常和打日志 spring aop的概念&#xff0c;很早就写博客介绍了&#xff0c;现在在工作中真正使用。 我们很容易写出的代码 我们很容易写出带有很多try catch 和 logger.warn(),logger.error()的代码&#xff0c;这样一个方法本来的业务逻辑只有5行&a…

Matlab与线性代数 -- 矩阵的重组5

本图文详细介绍了矩阵重组的Matlab命令reshape()。

windows XP下Python2.7包管理工具安装-setuptool,pip、distribute、nose、virtualenv

在Python开发中为了对项目进行管理和调试。必须安装一些特定的软件包。据说业内这个叫做yak shaving-做一个非常酷非常绚丽的Python项目之前&#xff0c;必须做的一些枯燥无味的准备工作。本文介绍了setuptool。pip、distribute、nose、virtualenv的安装。 1&#xff0c;pytho…

黑客必知的SQL语句 黑客知道,程序员必知

SQL语句先前写的时候&#xff0c;很容易把一些特殊的用法忘记&#xff0c;我特此整理了一下SQL语句操作。 一、基础 1、说明&#xff1a;创建数据库 Create DATABASE database-name 2、说明&#xff1a;删除数据库 drop database dbname 3、说明&#xff1a;备份sql server --…

AutowireCapableBeanFactory,实现不必配置xml文件,动态加载bean

场景 今天遇见一个问题&#xff0c;如何能做到一个类&#xff0c;没有在spring的配置文件中配置&#xff0c;但是还能通过某种方式加载进来。通过查看一些代码&#xff0c;查看stackoverflow&#xff0c;了解了一些知识。 如果一个类并没有在applicationContext中配置我们可以…

[导入]如何理解Return的返回值?

如何理解Return的返回值&#xff1f; 问题&#xff1a; 在创建和录制脚本的时候&#xff0c;发现在脚本vuser_init、Action、vuser_end三部分&#xff0c;都会有一条“return 0;”语句&#xff0c;那么我们平时在编写脚本时如何应用return语句&#xff0c;return不同的返回值又…

如何利用神经网络结合遗传算法进行非线性函数极值寻优(2)

如何利用神经网络结合遗传算法进行非线性函数极值寻优

自己亲自写的两本linux资料,免费下载,pdf文档

第一本是我写的韩顺平老师解说的linux视频的笔记&#xff0c;该视频原本有21讲&#xff0c;可是我始终没有找到当中的17、18讲。可是其它部分我感觉及记录的还是蛮认真的。该套视频解说的非常基础&#xff0c;因此我的这本笔记也非常基础。这里是免积分在csdn上的下载地址&…

深入理解Java:SimpleDateFormat安全的时间格式化

转自&#xff1a;http://www.cnblogs.com/peida/archive/2013/05/31/3070790.html 想必大家对SimpleDateFormat并不陌生。SimpleDateFormat 是 Java 中一个非常常用的类&#xff0c;该类用来对日期字符串进行解析和格式化输出&#xff0c;但如果使用不小心会导致非常微妙和难以…

如何提高增加包含大量记录的表的主键字段的效率

如何提高增加包含大量记录的表的主键字段的效率 LazyBee 1 问题的提出&#xff1a; 在给客户升级数据库系统时&#xff0c;由于报表的需要&#xff0c;系统中每一个表都需要有主键字段。系统审计表自然也有这个要求—需要增加一个identify的字段&#xff0c;但这个表中有2000多…

${pageContext.request.contextPath} JSP取得绝对路径

在使用的时候可以使用${pageContext.request.contextPath}&#xff0c;也同时可以使用<%request.getContextPath()%>达到同样的效果&#xff0c;同时&#xff0c;也可以将${pageContext.request.contextPath}&#xff0c;放入一个JSP文件中&#xff0c;将用C&#xff1a;…

Matlab与线性代数 -- 矩阵的水平连接和垂直连接

本图文详细介绍了Matlab中矩阵的水平连接和垂直连接。

Matlab与线性代数 -- 矩阵的复制

本图文详细介绍了Matlab中矩阵复制函数repmat(A,m,n)。

用C#实现抽象工厂模式

大家都知道&#xff0c;在开发中&#xff0c;如果用好了某种模式&#xff0c;那效率…… 嘿嘿 我就不说了 进入正题吧&#xff1a; 以下都为源代码&#xff0c;可直接拷贝&#xff0c;然后自己研究 由于是讲解&#xff0c;所以只涉及基本的架构 项目名为&#xff1a;Ab…

树莓派 raspberry安全关机命令重启命令

树莓派可以通过下面几个命令来实现安全关机&#xff1a;sudo shutdown -h now sudo halt sudo poweroff sudo init 0上面四行代码都可以&#xff0c;执行一行都可以安全关机, ^_^树莓派重启 定时重启方法&#xff1a;sudo reboot shutdown -r now shutdown -r 04:00:00 #定时重…

jps命令(Java Virtual Machine Process Status Tool)(转)

1、介绍 用来查看基于HotSpot的JVM里面中&#xff0c;所有具有访问权限的Java进程的具体状态, 包括进程ID&#xff0c;进程启动的路径及启动参数等等&#xff0c;与unix上的ps类似&#xff0c;只不过jps是用来显示java进程&#xff0c;可以把jps理解为ps的一个子集。 使用jps时…