oracle数组定义与使用
- 定义固定长度的一维数组
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数组定义与使用的更多相关文章
- oracle数组学习资料
--oracle数组,所谓数组就是 字段的 个数,数组应该很有用 --可变数组 declare type v_ar is varray(10) of varchar2(30); my_ar v ...
- java plsql 调用oracle数组类型
首先当然是在oracle中建立type CREATE OR REPLACE TYPE cux_proxy_bid_award_rec IS OBJECT ( trading_partner_id NU ...
- JS数组定义及详解
1.什么是数组 数组就是一组数据的集合 其表现形式就是内存中的一段连续的内存地址 数组名称其实就是连续内存地址的首地址 2.关于js中的数组特点 数组定义时无需指定数据类型 数组定义时可以无需指定数组 ...
- C#的一维数组和二维数组定义方式:
一维数组: //一维数组定义与初始化 ,, };//第一种方式 , , }; //第二种方式 int[] one3; //第三种方式 one3=,,}; 二维数组: //二维数组定义与初始化 //不规 ...
- php 数组定义、取值和遍历
<?php //常用函数 //生成随机数 //echo rand(1,10); //两个参数来确定随机数的范围 //日期时间函数 //var_dump(time()); //取当前时间的UNIX ...
- linux源码阅读笔记 数组定义
在阅读linux源码的过程中遇到了下面的略显奇怪的结构体数组定义. static struct hd_struct{ long start_sect; long nr_sects; }hd[10]={ ...
- JS数组定义
JS数组定义收藏 function StorePage(){d=document;t=d.selection?(d.selection.type!='None'?d.selection.create ...
- js便利关联数组 及数组定义方式 分类
"http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv=& ...
- Javascript Jquery 中的数组定义与操作_子木玲_新浪博客
body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI& ...
随机推荐
- winform下载网页源码
public partial class Form1 : Form{public Form1(){InitializeComponent();} private void button1_Click( ...
- js共享onload事件
问题:通过js进行事件绑定,必须在HTML文档加载完成后再执行js脚本,否则可能因DOM不完整导致无法完成预计的效果,但对于不同的需求如何选用最佳的实现方式呢,这里做了整理,可以做参考. 一.对于小型 ...
- Linux内核监控模块-1-驱动模块(LKM)开发(以一个简单的hello world程序为例)
在上面一篇中介绍到,监控模块要做成一个驱动模块(或者说是可加载模块,LKM),动态的加载到Linux内核中.那么这篇就简单的介绍一下怎样做一个这样的驱动模块. 以简单的hello world程序为 ...
- jQuery Mobile 控制 select 的显示隐藏 display none
如需要动态控制下拉选择菜单select的显隐,一般考虑使用display:none这个方法. 但在jQueryMobile中的select添加自定义的css,display:none 是无效的. 解决 ...
- NEURAL NETWORKS, PART 1: BACKGROUND
NEURAL NETWORKS, PART 1: BACKGROUND Artificial neural networks (NN for short) are practical, elegant ...
- android ADT Bundle for Mac下载地址
直接下载解压就能用 http://developer.android.com/sdk/index.html
- [spring-framework]Spring定时器的配置和使用
开发中我们常常会做一些定时任务,这些任务有开始时间,并会按一定的周期或规则执行.如此我们在Java程序开发中使用定时器来处理定时任务. <!-- MessageRequestTask类中包含了m ...
- java:找出占用CPU资源最多的那个线程(HOW TO)
在这里对linux下.sun(oracle) JDK的线程资源占用问题的查找步骤做一个小结:linux环境下,当发现java进程占用CPU资源很高,且又要想更进一步查出哪一个java线程占用了CPU资 ...
- 【CF】474E Pillars
H的范围是10^15,DP方程很容易想到.但是因为H的范围太大了,而n的范围还算可以接受.因此,对高度排序排重后.使用新的索引建立线段树,使用线段树查询当前高度区间内的最大值,以及该最大值的前趋索引. ...
- Java数据库编程
ava与数据库交互的主要API是jdbc.jdbc的主要目的是: 1.通过使用SQL或者专有的SQL扩展,程序员可以利用java语言开发访问数据的应用. 2.数据库开发商或者数据库工具开发商改进数据库 ...