1.如何在PL/SQL中创建和使用Nested table;
2.如何在PL/SQL中创建和使用Record;

1.如何在PL/SQL中创建和使用Nested table

 DECLARE
/**创建一个 nested table **/
TYPE type_nstb_noind_var is table of varchar2(300);
/** 创建一个索引类型为varchar的nested table,也可以指定其它类型(BINARY_INTEGER、PLS_INTEGER、String、Long、RAW、LONG RAW、ROWID,CHAR,CHARACTER) **/
Type type_nstb_var is table of varchar2(300) index by varchar2(30); /** 创建一个包含索引并且不能为空的 nested table **/
Type type_nstb_con_notnull is table of varchar2(300) index by varchar2(300) not null;
/** 根据 emp 表的ename列类型创建 nested table **/
TYPE type_nstb_ename is table of emp.ename%type; /**定义游标 **/
CURSOR MYCUR IS SELECT ENAME FROM EMP; /**根据游标类型创建 nested table **/
type type_nestb_bycur is table of mycur%rowtype; /** nested table 没有存储值限制,未初始化时默认值为null,使用时要引用 **/
/** 定义变量引用 **/
v_noind type_nstb_noind_var;
v_var type_nstb_var;
v_noind_append type_nstb_noind_var;
v_noind_delete type_nstb_noind_var; PROCEDURE P(STR VARCHAR2) is
BEGIN
DBMS_OUTPUT.PUT_LINE(STR);
END; BEGIN
/**初始化 nested table:**/
v_noind:=type_nstb_noind_var('American','China','Japan'); /**每个位值不能超过指定最大值**/
P('get v_noind first index value: '||V_NOIND.FIRST);/**获得第一个索引下标值**/
P('get v_noind last index value: '||V_NOIND.LAST); /**获得最后一个索引下标值**/
P('get v_noind by index 1: '||V_NOIND(1)); /**获得第一个索引下标对应值**/
p('get v_noind first value by first index value: '||v_noind(v_noind.first)); /**也可以这样获取值**/
v_noind(3):='Englind'; /**替换一个索引下标对应的值**/ /**输出所有值 **/
FOR J IN V_NOIND.FIRST..V_NOIND.LAST LOOP
P('using loop print v_noind('||j||') value:'||V_NOIND(J));
END LOOP; /** 从emp表中取出ename列所有值到nested table **/
SELECT ENAME BULK COLLECT INTO V_NOIND FROM EMP; /**如果涉及操作的数据量比较大,可以先定义游标,然后分批从游标中提取数据**/
OPEN MYCUR; /** 打开游标 **/
FETCH MYCUR BULK COLLECT INTO V_NOIND LIMIT 10; /**10代表每次提取的数据量,这在批量处理更新数据是会很有用**/
LOOP
FOR I IN V_NOIND.FIRST..V_NOIND.LAST LOOP
P('v_noind('||i||')value:'||V_NOIND(I));
END LOOP;
FETCH MYCUR BULK COLLECT INTO V_NOIND LIMIT 10;
EXIT WHEN MYCUR%NOTFOUND; /** 当游标内无数据是退出循环 **/
END LOOP;
CLOSE MYCUR; /** 关闭游标 **/ /** 也可以像这样取数 **/
OPEN MYCUR;
LOOP FETCH MYCUR BULK COLLECT INTO V_NOIND LIMIT 10;
FOR I IN V_NOIND.FIRST..V_NOIND.LAST LOOP
P(V_NOIND(I));
END LOOP;
EXIT WHEN MYCUR%NOTFOUND;
END LOOP; /** Nested table 未指定索引下标类型时,默认为number类型;如果想保存其它类型的索引下标类型,则在创建Nested table 时指定 INDEX BY VARCHAR2(300)或其它类型(BINARY_INTEGER、PLS_INTEGER、String、Long、RAW、LONG RAW、ROWID,CHAR,CHARACTER) **/
/**为索引下标类型为varchar2的nested table赋值**/
v_var('A'):='China';
v_var('B'):='Japen';
v_var('C'):='German';
p('get v_var first index value: '||v_var.first); /**获得第一个索引下标**/
p('get v_var first value: '||v_var(v_var.first)); /**获得第一个索引下标对应的值**/
p('get v_var contain element count: '||v_var.count); /**获得Nested table 存储总数**/
if(v_var.exists('B'))then /**判断某个索引下标值是否存在**/
p('China has in v_var nested table');
end if; p('get v_var next value by index "B":'||v_var(v_var.next('B'))); /** 获取索引下标'B'的下一个值 **/
p('get v_var prior value by index "C":'||v_var(v_var.prior('C'))); /** 获取索引下标'C'的上一个值 **/

/**遍历**/
v_first:=v_var.first;
loop
dbms_output.put_line(v_first);
v_first:=v_var.next(v_first);
if(v_first=v_var.last)then
exit;
end if;
end loop;
/**向nested table 内添加项,此方法不能用于指定了索引下标类型 INDEX BY ..的nested table **/
v_noind_append:=type_nstb_noind_var();
v_noind_append.extend; /**向nested table 内添加一个空项**/
v_noind_append.extend(2); /** 向nested table 内添加一个索引下标为2的项 **/
v_noind_append(2):='Append2'; /** 为刚添加的索引下标项2赋值 **/
v_noind_append.extend(3,2); /** 根据索引下标为2 的项在nested table 内添加3个新项,值一样,但索引下标不一样**/
for i in v_noind_append.first..v_noind_append.last loop
p('v_noind('||i||'):'||v_noind_append(i));
end loop; v_noind_delete:=type_nstb_noind_var('one','two','three','four','five','six','seven','eight','night','ten');
v_noind_delete.delete(1); /**删除nested table 项1**/
v_noind_delete.delete(2,4);/**删除第2项到第4项**/
v_var.delete('A'); /**如果定义type是使用了INDEX BY.. 指定索引项类型,则可以通过key删除项**/
for i in v_noind_delete.first..v_noind_delete.last loop /**注意如果删除中间项后打印会报错(ORA-01403: no data found)**/
p('print after delete v_noind_delete('||i||'):'||v_noind_delete(i));
end loop;
END;

2.如何在PL/SQL中创建和使用Record

declare
type nstb_job is table of varchar2(30) ; /**定义Record**/
type ts_record is record
(
id emp.empno%type, /**定义record字段id类型是emp表empno列类型**/
name varchar2(30), /**定义record字段name类型是varchar2**/
dept Tdept%rowtype, /**定义record 字段dept类型是tdept表 **/
item_no number(5) not null :=10,/**定义record字段item_no字段不能为空且默认值是10 注:指定不能为空时必须有默认值**/
job NSTB_JOB, /**定义record字段job 类型是nested table**/
orderno number :=10 /**定义record 字段orderno并初始化**/
);
rd_emp emp%rowtype; /**定义record tb_emp,字段内容是emp表**/
ts ts_record; /**使用record前必须引用**/ PROCEDURE P(STR VARCHAR2) is
BEGIN
DBMS_OUTPUT.PUT_LINE(STR);
END; begin
/**初始化record***/
ts.id:=100;
ts.name:='sywu';
ts.dept.deptno:=12; /**因为dept是类型(表),初始化时必须初始化类型(表)**/
ts.dept.dname:='IBM';
ts.dept.loc:='ssdtes';
ts.job:=NSTB_JOB('java developer','oracle database administrator'); /**初始化job,注意:如果定义类型时指定了Index by .. 是不能这样初始化的,会报类型不在此区域错误**/
p('id:'||ts.id||' name:'||ts.name||' deptno:'||ts.dept.deptno||' job:'||ts.job(ts.job.first)); /**将dept 表中的某一列导入到record ts的dept 类型中**/
select * into ts.dept from dept where rownum=1;
p('deptno:'||ts.dept.deptno||' dname:'||ts.dept.dname||' loc:'||ts.dept.loc); /**将emp 表中的某一列导入到record rd_emp中**/
select * into rd_emp from emp where empno=7369;
p('empno:'||rd_emp.empno||' job:'||rd_emp.job);
end;

总结:Nested table: 无存储值限值,可以存储一条或多条记录,无需初始化,默认为null,可以在数据库或PL/SQL中使用.可以使用默认索引下标或定义索引下标,自定义添加删除项,可以分批提取游标中的数据,使用时必须引用;
Record:一次运行中只能提取一条记录,只能在PL/SQL中使用,不能在数据库中使用,可以定义类型、数据类型字段;可以在函数、存储过程中做参数使用。

Oracle Nested table、Record的更多相关文章

  1. [独孤九剑]Oracle知识点梳理(五)数据库常用对象之Table、View

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  2. Oracle GoldenGate 三、加密

    写在开始前 从上周开始,我花了大量的业余时间阅读GoldenGate官方文档,并根据文档实践和进一步学习了解GoldenGate,以下便是根据官方文档理解总结的GoldenGate学习内容: Orac ...

  3. Oracle GoldenGate 二、配置和使用

    Oracle GoldenGate 二.配置和使用 配置和使用GoldenGate的步骤 1 在源端和目标端配置数据库支持GoldenGate 2 在源端和目标端创建和配置GoldenGate实例 3 ...

  4. Oracle索引梳理系列(七)- Oracle唯一索引、普通索引及约束的关系

    版权声明:本文发布于http://www.cnblogs.com/yumiko/,版权由Yumiko_sunny所有,欢迎转载.转载时,请在文章明显位置注明原文链接.若在未经作者同意的情况下,将本文内 ...

  5. Oracle删除表、字段之前判断表、字段是否存在

    这篇文章主要介绍了Oracle删除表.字段之前判断表.字段是否存在的相关资料,需要的朋友可以参考下 在Oracle中若删除一个不存在的表,如 “DROP TABLE tableName”,则会提示: ...

  6. Oracle系列:记录Record

    Oracle系列:记录Record   分类: [Oracle] (15) 版权声明:本文为博主原创文章,未经博主允许不得转载. Oracle系列:记录(Record) 一,什么是记录(Record) ...

  7. oracle partition table 分区表详解

    Oracle partition table 分区表详解 分区表就是通过使用分区技术,将一张大表,拆分成多个表分区(独立的segment),从而提升数据访问的性能,以及日常的可维护性.分区表中,每个分 ...

  8. oracle闪回、闪回数据归档Flashback Data Archive (Oracle Total Recall)的真正强大之处、11gR2增强以及合理使用

    oracle的闪回很早就出来了,准确的说一直以来应该都较少被真正用户广为使用,除了dba和极少部分开发人员偶尔用于逻辑出错.误删恢复之外,较少被用于产生更有价值的用途. 各种闪回表flashback ...

  9. Oracle 基本操作--数据类型、修改和删除表、增删改查和复制表

    一.Oracle基础数据类型:数据类型: 创建数据表时,设计数据表的结构问题,也就是设计及确定数据表中各个列的数据类型,是数值.字符.日期还是图像等其他类型. 因为只有设计好数据表结构,系统才会在磁盘 ...

随机推荐

  1. HDOJ5521(巧妙构建完全图)

    Meeting Time Limit: 12000/6000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others)Total ...

  2. java web 程序---登陆验证4个页面

    思路: 1.第一个是登陆页面login.jsp一个form表单.点击登陆按钮 2.第二个是验证页面check.jsp.如果username和password都正确.则跳转到另一个页面a.jsp显示登陆 ...

  3. Mysql auto_increment总结

    一.为什么InnoDB表要建议用自增列做主键 我们先了解下InnoDB引擎表的一些关键特征: InnoDB引擎表是基于B+树的索引组织表(IOT): 每个表都需要有一个聚集索引(clustered i ...

  4. Lock分析

      Lock接口是锁的实现,用来控制多个线程访问共享资源的方式,是在java 1.5的时候引入的,在此之前,只能通过synchronized的方式来取得对象的锁. synchronized中的锁是隐式 ...

  5. 【洛谷】P1388 算式(dp)

    题目描述 给出N个数字,不改变它们的相对位置,在中间加入K个乘号和N-K-1个加号,(括号随便加)使最终结果尽量大.因为乘号和加号一共就是N-1个了,所以恰好每两个相邻数字之间都有一个符号.例如: N ...

  6. Entity Framework API介绍 -- DbSet<>().Find()

    过去我们常常使用Where或First(FirstOrDefault)方法来查找对应的实体,比如: var query = context.CertInfoMakeDetails.ToList().W ...

  7. 1_python小程序之实现用户的注册登陆验证功能

    python小程序之实现用户的注册登陆验证功能 程序扼要简述:  一.程序流程:1.程序开始2.判断本地文件/数据库是否已存在用户信息,存在则跳转到登陆,否则跳转到注册,注册成功后后跳转到登陆3.判断 ...

  8. Julia - 函数的参数传递

    不定参数 不定参数的函数也称变参函数 函数的参数可以被定义成任意个 可以在最后一个参数后紧跟省略号“...”来定义变参函数 julia> bar(x, y, z...) = (x, y, z) ...

  9. Django模型层

    ORM简介: MVC或者MTV框架中包括一个重要的部分就是ORM,它实现了数据模型与数据库的解耦,即数据模型的设计不需要依赖特定的数据库,通过简单的配置就可以轻松更换数据库,这极大的减轻了开发人员的工 ...

  10. 25_java之Properities集合|对象序列化和反序列化

    01Properties集合的特点 * A: Properties集合的特点 * a: Properties类介绍 * Properties 类表示了一个持久的属性集.Properties 可保存在流 ...