• 定义固定长度的一维数组
      type type_array is varray(10) of varchar2(20);

1、varray(10)表示定义长度为10的数组

2、varchar2(20)表示数组为字符型,且元素字符串长度不超过20

  • 定义可变长度的一维数组
      type type_array is table of varchar2(20) index by binary_integer;   

1、table表示可变长度

2、index by binary_integer 表示以符号整数为索引

一维数组的初始化

/*初始化为空数组*/

      var_array type_array := type_array();

/*初始化为六个元素数组*/

      var_array type_array := type_array('ggs','jjh','wsb','csl','dd','bb'); 

/*直接对各个元素进行赋值*/

      var_array.extend(3);
var_array(1) = '1';
var_array(2) = '2';
var_array(3) = '3'; /*通过遍历数组元素方式进行初始化操作*/
for i in 1..var_array.count loop
var_array(i) = to_char(i);
end loop;

1、oracle数组的索引从1开始,而不是从0开始2、count为数组的长度

  • 定义多维数组
      type type_array is table of Tbl_User % rowtype index by binary_integer;  

说明:Tbl_User 为基础表

多维数组的初始化

      select *
bulk collect into var_array
from t_user;

说明:bulk collect 表示将批量查询数据直接插入collection中,而不是通过cursur一条条插入

多维数组的读取方法

      for i in 1..var_array.count loop
dbms_output.put_line(var_array(i).user_id);
dbms_output.put_line(var_array(i).username);
end loop;
  • Oracle调用函数返回的数组

方法一

      declare
aa Tbl_StrSplit := Tbl_StrSplit();
begin
aa := PKG_TCH_COURSE_INIT.Fn_GetTermDate('root', 2);
dbms_output.put_line(aa(1));
dbms_output.put_line(aa(2));
end;

方法二

      Select Fn_GetTermDate(P_SchoolKey, P_TermKey)
Into Tbl_TermDate
From dual;
  • 强制修改已经被引用的自定义type

修改自定义type类型的OBJTYPE_VAR时失败

OBJTYPE_VAR原有结构

      CREATE OR REPLACE TYPE "OBJTYPE_VAR"  AS OBJECT
(
field0 VARCHAR2(1000),
field1 VARCHAR2(1000)
)

修改后的新结构

      CREATE OR REPLACE TYPE "OBJTYPE_VAR"  AS OBJECT
(
serialNo Number,
field0 VARCHAR2(1000),
field1 VARCHAR2(1000)
)

执行修改时提示错误

“cannot drop or replace a type with type or table  dependents”

原因是已经在其他地方使用了OBJTYPE_VAR,oracle不允许直接修改修改或删除被引用的OBJTYPE_VAR,但可以通过加上force关键字强制执行。

强制重新创建

      CREATE OR REPLACE TYPE "OBJTYPE_VAR"  FORCE  AS OBJECT
(
serialNo NUMBER,
field0 VARCHAR2(1000),
field1 VARCHAR2(1000)
)

强制删除掉OBJTYPE_VAR

      drop type OBJTYPE_VAR force

定义一维可变数组

      CREATE OR REPLACE TYPE "TBLTYP_VAR"    Is Table Of  VARCHAR2 (32767);

      CREATE OR REPLACE TYPE "TBLTYP_Int"    Is Table Of  Pls_Integer;

定义三维可变数组

      CREATE OR REPLACE TYPE "OBJTYPE_VAR"  FORCE  AS OBJECT
(
serialNo NUMBER,
field0 VARCHAR2(1000),
field1 VARCHAR2(1000)
)
  • oracle数组属性和函数

COUNT             返回集合中元素的个数   
DELETE            删除集合中所有元素    
DELETE(x)         删除元素下标为x的元素      对VARRAY非法     
DELETE(x,y)       删除元素下标从X到Y的元素   对VARRAY非法

EXIST(x)          如果集合元素x已经初始化,则返回TRUE, 否则返回FALSE    
EXTEND            在集合末尾添加一个元素      对Index_by非法    
EXTEND(x)         在集合末尾添加x个元素       对Index_by非法    
EXTEND(x,n)       在集合末尾添加元素n的x个副本 对Index_by非法    
FIRST             返回集合中的第一个元素的下标号,对于VARRAY集合始终返回1。

LAST              返回集合中最后一个元素的下标号, 对于VARRAY返回值始终等于COUNT.    
LIMIT             返回VARRY集合的最大的元素个数   Index_by集合和嵌套表无用    
NEXT(x)           返回在第x个元素之后及紧挨着它的元素值,如果x是最后一个元素,返回null.    
PRIOR(x)          返回在第x个元素之前紧挨着它的元素的值,如果x是第一个元素,则返回null。    
TRIM              从集合末端开始删除一个元素  对于index_by不合法

TRIM(x)           从集合末端开始删除x个元素

oracle数组定义与使用的更多相关文章

  1. oracle数组学习资料

    --oracle数组,所谓数组就是  字段的 个数,数组应该很有用 --可变数组 declare  type v_ar is varray(10) of varchar2(30);   my_ar v ...

  2. java plsql 调用oracle数组类型

    首先当然是在oracle中建立type CREATE OR REPLACE TYPE cux_proxy_bid_award_rec IS OBJECT ( trading_partner_id NU ...

  3. JS数组定义及详解

    1.什么是数组 数组就是一组数据的集合 其表现形式就是内存中的一段连续的内存地址 数组名称其实就是连续内存地址的首地址 2.关于js中的数组特点 数组定义时无需指定数据类型 数组定义时可以无需指定数组 ...

  4. C#的一维数组和二维数组定义方式:

    一维数组: //一维数组定义与初始化 ,, };//第一种方式 , , }; //第二种方式 int[] one3; //第三种方式 one3=,,}; 二维数组: //二维数组定义与初始化 //不规 ...

  5. php 数组定义、取值和遍历

    <?php //常用函数 //生成随机数 //echo rand(1,10); //两个参数来确定随机数的范围 //日期时间函数 //var_dump(time()); //取当前时间的UNIX ...

  6. linux源码阅读笔记 数组定义

    在阅读linux源码的过程中遇到了下面的略显奇怪的结构体数组定义. static struct hd_struct{ long start_sect; long nr_sects; }hd[10]={ ...

  7. JS数组定义

     JS数组定义收藏 function StorePage(){d=document;t=d.selection?(d.selection.type!='None'?d.selection.create ...

  8. js便利关联数组 及数组定义方式 分类

    "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv=& ...

  9. Javascript Jquery 中的数组定义与操作_子木玲_新浪博客

    body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...

随机推荐

  1. 卷积神经网络 cnnff.m程序 中的前向传播算法 数据 分步解析

    最近在学习卷积神经网络,哎,真的是一头雾水!最后决定从阅读CNN程序下手! 程序来源于GitHub的DeepLearnToolbox 由于确实缺乏理论基础,所以,先从程序的数据流入手,虽然对高手来讲, ...

  2. 欧拉计划 NO05 ps:4题想过,好做,但麻烦,有时间补充,这题也不难!

    问题重述: 2520 is the smallest number that can be divided by each of the numbers from 1 to 10 without an ...

  3. python获取本地ip地址的方法

    #_*_coding:utf8_*_ #以下两种方法可以在ubuntu下或者windows下获得本地的IP地址 import socket # 方法一 localIP = socket.gethost ...

  4. March of the Penguins

    poj3498:http://poj.org/problem?id=3498 题意:某个冰块上有a只企鹅,总共可以跳出去b只,问是否可能所有的企鹅都跳到某一块冰块上,输出所有的可能的冰块的编号. 由于 ...

  5. 如何在DJANGO里,向有外键(一对多和多对多)的DB里插入数据?

    需要插入的数据表结构如下: class UserInfo(models.Model): user_id =models.AutoField(primary_key=True) user_name=mo ...

  6. asp.net 类库中获取session c#类中获取session

    asp.net  类库中获取session c#类中获取session 1. 先引入命名空间 using System.Web; using System.Web.SessionState; 在使用H ...

  7. ADI加速度计基础原理

  8. Scarborough Fair 绝美天籁

    很少见的男声唱法,而且还古色古香: https://www.youtube.com/watch?v=sgbo2QWLBzI https://www.youtube.com/watch?v=-BakWV ...

  9. 在 ActionBar 添加刷新按钮

    在以前版本的 Gmail 应用中,ActionBar 上有个刷新菜单,点击一下刷新菜单变成一个转圈的刷新标示动画图片. 之前实现该功能的时候都是使用一个类库 RefreshActionItem来实现的 ...

  10. Android 对话框弹出位置和透明度

    在Android中我们经常会用AlertDialog来显示对话框.通过这个对话框是显示在屏幕中心的.但在某些程序中,要求对话框可以显示在不同的位置.例如,屏幕的上方或下方.要实现这种效果.就需要获得对 ...