데이터 베이스 MySQL 튜토리얼 oracle数组类型简单实例介绍

oracle数组类型简单实例介绍

Jun 07, 2016 pm 05:46 PM
배열 유형

本文章详细的介绍了关于oracle数组的各种操作,有需要的同学可以参考一下。

本文章详细的介绍了关于oracle数组的各种操作,有需要的同学可以参考一下。

Oracle数组一般可以分为固定数组和可变数组
 固定数组 
 
 

 代码如下 复制代码
declare 
 type v_ar is varray(10) of varchar2(30);  
 my_ar v_ar:=v_ar('g','m','d','龚','帅');  
 begin 
       for i in 1..my_ar.count 
       loop  
           dbms_output.put_line(my_ar(i));  
       end loop;  
 end; 
 declare
 type v_ar is varray(10) of varchar2(30);
 my_ar v_ar:=v_ar('g','m','d','龚','帅');
 begin
       for i in 1..my_ar.count
       loop
           dbms_output.put_line(my_ar(i));
       end loop;
 end;
 
 --可变数组
 --一维数组
 
 declare 
 type v_table is table of varchar2(30) index by binary_integer;  
 --类型可以是前面的类型定义,index by binary_integer子句代表以符号整数为索引,  
 --这样访问表类型变量中的数据方法就是“表变量名(索引符号整数)”。  
 my_table v_table;  
 begin 
       for i in 1..20  
       loop  
           my_table(i):=i;  
           dbms_output.put_line(my_table(i));  
       end loop;  
 end; 
 declare
 type v_table is table of varchar2(30) index by binary_integer;
 --类型可以是前面的类型定义,index by binary_integer子句代表以符号整数为索引,
 --这样访问表类型变量中的数据方法就是“表变量名(索引符号整数)”。
 my_table v_table;
 begin
       for i in 1..20
       loop
           my_table(i):=i;
           dbms_output.put_line(my_table(i));
       end loop;
 end;
 
 --多维数组--多条记录
 
 
 declare 
 type v_table is table of t_user%rowtype index by binary_integer;  
 my_table v_table;  
 begin 
       * bulk collect into my_table from t_user;  
       for i in 1..my_table.count/10 --my_table.count/10取到的值为四舍五入值  
       loop  
           dbms_output.put_line('suser--'||my_table(i).suser);  
          dbms_output.put_line('name---'||my_table(i).name);  
           dbms_output.put_line('sex----'||my_table(i).sex);  
       end loop;  
 end; 
 declare
 type v_table is table of t_user%rowtype index by binary_integer;
 my_table v_table;
 begin
       select * bulk collect into my_table from t_user;
       for i in 1..my_table.count/10 --my_table.count/10取到的值为四舍五入值
       loop
           dbms_output.put_line('suser--'||my_table(i).suser);
           dbms_output.put_line('name---'||my_table(i).name);
           dbms_output.put_line('sex----'||my_table(i).sex);
       end loop;
 end;
 
 多维数组--单条记录
 
 
 declare 
 type v_table is table of t_user%rowtype index by binary_integer;  
 my_table v_table;  
 begin 
       select * into my_table(9) from t_user where suser='admin';  
      --my_table(i) i可以为任意整数,但取值时必须保持以i一致;  
       dbms_output.put_line('--suser--'||my_table(9).suser||'--name--'||my_table(9).name);   
 end; 
 declare
 type v_table is table of t_user%rowtype index by binary_integer;
 my_table v_table;
 begin
       select * into my_table(9) from t_user where suser='admin';
       --my_table(i) i可以为任意整数,但取值时必须保持以i一致;
       dbms_output.put_line('--suser--'||my_table(9).suser||'--name--'||my_table(9).name);
 end;
 
 --自定义数组
 
 create or replace type varray_list as varray(30) of varchar2(50);  
 --使用自定义数组  
 create or replace procedure show_list(p_varlist in varray_list)  
 is 
 v_str varchar2(50);  
 begin 
       for i in 1..p_varlist.count   
       loop  
           v_str:=p_varlist(i);  
           dbms_output.put_line('v_str='||v_str);  
           dbms_output.put_line('p_varlist('||i||')='||p_varlist(i));  
       end loop;  
 end;  
  
 declare 
 my_var varray_list:=varray_list('g','m','d','龚','帅');  
 begin 
       show_list(my_var);   
 end;

实例

 代码如下 复制代码

--固定数组
declare
  type type_array is varray(10) of varchar2(20);
  var_array type_array:=type_array('ggs','jjh','wsb','csl','dd','bb');
begin
  for i in 1..var_array.count loop
      dbms_output.put_line(var_array(i));
  end loop;
end;

--可变数组
declare
  type type_array is table of varchar2(20) index by binary_integer;
  var_array type_array;
begin
  var_array(1):='aa';
  var_array(2):='bb';
 
  for i in 1..var_array.count loop
     dbms_output.put_line( var_array(i));
  end loop;
 
end;

--可变数组取表
declare
begin
 
end;

create or replace procedure proc_stock(n number)
as    
       var_stock_code varchar2(10);
       var_stock_price number;
begin
       for i in 1..n loop
           var_stock_code:= lpad(STR1 =>i ,LEN =>6 ,PAD =>'0' ) ;
          
           var_stock_price:=trunc(dbms_random.value*100)+1;
           --dbms_output.put_line(var_stock_code);
           --dbms_output.put_line(var_stock_price);
           insert into t_stock (stockcode,stockprice)
                  values(var_stock_code,var_stock_price);
           commit;      
       end loop;
end;
declare
begin
       proc_stock(1000000);
end;
--用游标访问 14.578秒 13.5 13.8
declare
       cursor cur is select * from t_stock;
       row_stock t_stock%rowtype;
begin
       open cur;
       loop
            fetch cur into row_stock;
            exit when cur%notfound;
            null;
       end loop;
       close cur;
end;

--用数组实现 4.813 1.953 2
declare
       type type_array is table of t_stock%rowtype index by binary_integer;
       var_array type_array;
begin
       select * bulk collect into var_array from t_stock;
       for i in 1..var_array.count loop         
           null;
       end loop;
end;

--访问自定义表
declare
       type type_record is record(
            username varchar2(20),
            sex varchar2(2)
       );
       type_record_user  type_record;
       type type_array is table of type_record_user%type index by binary_integer;
       var_array type_array;      
begin
       select username,sex bulk collect into var_array from tuser;
       for i in 1..var_array.count loop
           dbms_output.put_line(var_array(i).username);
           dbms_output.put_line(var_array(i).sex);
       end loop;
end;

关于ORACLE中的数组:记录同集合
集合可以有三种实现方式:
1 自定义一个TYPE使用VARRAY来得到一个数组但只能对基本类型定义如:
CREATE TYPE 类型名 AS VARRAY OF VARCHAR2(20);


1 自定义一个TYPE使用VARRAY来得到一个数组但只能对基本类型定义如:
CREATE TYPE 类型名 AS VARRAY(52) OF VARCHAR2(20);

不能使用如下:
CREATE TYPE 类型名 AS VARRAY(52) OF 表名%ROWTYPE;
注意:使用VARRAY时一定要先指定数组大小
不然搞创建数组类型

2 内嵌表如:
 TYPE 类型名 IS TABLE OF 具体类型如:(表名%ROWTYPE);
 内嵌表数组分二种:Index_by表同嵌套表如上的就是嵌套表而Index_by表只要在其尾回上 INDEX BY

BINARY_INTEGER就可以了
例子:

 代码如下 复制代码
declare
cursor cur_test is select id,mc from test;
type t_test1 is table of varchar2(60) index by binary_integer;
type t_test2 is table of test%rowtype index by binary_integer;
var_test1 t_test1;
var_test2 t_test2;
var_new t_test2;
begin
SELECT id,mc INTO var_test2(0) FROM test WHERE id='111';
dbms_output.put_line('var_test2(0):'||var_test2(0).id||'---'||var_test2(0).mc);
SELECT id,mc INTO var_test2(8) FROM test WHERE id='333';
dbms_output.put_line('var_test2(8):'||var_test2(8).id||'---'||var_test2(8).mc);
var_new := var_test2;
dbms_output.put_line('===== copy var_test2 to var_new =====');
dbms_output.put_line('var_new(0):'||var_new(0).id||'---'||var_new(0).mc);
dbms_output.put_line('var_new(8):'||var_new(8).id||'---'||var_new(8).mc);
end;
===================================================================================
DECLARE
TYPE t_test1 IS TABLE OF test.id%TYPE;
TYPE t_test2 IS VARRAY (10) OF test.id%TYPE;
var_test1 t_test1;
var_test2 t_test2;
begin
--var_test1(1) := ('test1.1'); --没有初始化不能赋值
var_test1 := t_test1('test1.1','test1.2','test1.3');
dbms_output.put_line('var_test1: '||var_test1(1)||','||var_test1(2)||','||var_test1(3));
var_test2 := t_test2('test2.1','test2.2','test2.3');
dbms_output.put_line('var_test2: '||var_test2(1)||','||var_test2(2)||','||var_test2(3));
var_test1(2) := 'test1.2_update';
dbms_output.put_line('==== 修改了var_test1(2) ====');
dbms_output.put_line('var_test1: '||var_test1(1)||','||var_test1(2)||','||var_test1(3));
dbms_output.put_line(var_test1.next(3));
dbms_output.put_line('var_test2元素个数: '||var_test2.limit());
end;


嵌套表的元素可以是集合,注意赋值的时候是varray_element.record_column := 的形式.
除了构造函数外,集合还有很多内建函数,按照面向对象编成的叫法称之为方法。
方法==========描述====================================================================使用限


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个元素===============================================对

index_by不合法
********************************************************************************************
记录可以定义为:
TYPE 类型名 IS RECORDER (具休类型)
也可用:变量名 表名%ROWTYPE
例子:

隐式定义记录中,我们不用描述记录的每一个域,在声明记录变量时使用%ROWTYPE命令定义与表,

视图,游标有相同结构的记录。
有一些PL/SQL指令在使用隐式定义记录时没有使用%ROWTYPE属性,比如游标FOR循环或中的:old

和:new记录

 代码如下 复制代码
declare
t_record1 test%rowtype;
cursor cur_test(v_id in varchar2) is
select id,mc from test
where id t_record2 cur_test%rowtype;
begin
for row_test in cur_test('333') loop
t_record1.id := row_test.id;
t_record1.mc := row_test.mc;
t_record2.id := row_test.id;
t_record2.mc := row_test.id;
dbms_output.put_line('t_record1:'||t_record1.id||'---'||t_record1.mc);
dbms_output.put_line('t_record2:'||t_record2.id||'---'||t_record2.mc);
dbms_output.put_line('row_test:'||row_test.id||'---'||row_test.mc);
dbms_output.put_line('================loop '||cur_test%rowcount||' times.');
end loop;
exception when others then
dbms_output.put_line(sqlcode||sqlerrm);
end;
======================================================================================
declare
type t_record is record
(
id test.id%type,
mc test.mc%type
);
var_record t_record;
counter number default 0;
begin
for row_test in (select id,mc from test) loop
counter := counter + 1;
var_record.id := row_test.id;
var_record.mc := row_test.mc;
dbms_output.put_line('var_record:'||var_record.id||'---'||var_record.mc);
dbms_output.put_line('row_test:'||row_test.id||'---'||row_test.mc);
dbms_output.put_line('================loop '||counter||' times.');
end loop;
exception when others then
dbms_output.put_line(sqlcode||sqlerrm);
end;


三、综合实例BULK COLLECT的用法

 代码如下 复制代码

*/

set serverout on
DECLARE
TYPE t_record IS RECORD (
id number(18,0),
mc varchar2(50)
);
var_record t_record;
type t_test is table of t_record;
var_test t_test := t_test();
cursor cur_test is select id,mc from test;
begin
open cur_test;
fetch cur_test BULK COLLECT INTO var_test;
for i in 1..var_test.count() loop
dbms_output.put_line(var_test(i).id||'---'||var_test(i).mc);
end loop;
end;

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. 크로스 플레이가 있습니까?
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 배열 유형은 무엇입니까? PHP 배열 유형은 무엇입니까? Jun 01, 2023 am 10:41 AM

PHP 배열에는 두 가지 유형이 있습니다. 1. 인덱스 배열, 첨자는 기본적으로 0부터 시작하는 숫자로 구성됩니다. 각 숫자는 배열의 배열 요소 위치에 해당합니다. 2. 연관 배열, 첨자는 다음으로 구성됩니다. 숫자 값과 문자 문자열의 혼합으로 구성됩니다. 배열의 키 이름이 숫자가 아닌 경우 해당 배열은 연관 배열입니다.

PHP 배열에는 몇 개의 데이터 유형이 있습니까? PHP 배열에는 몇 개의 데이터 유형이 있습니까? Jun 06, 2023 pm 03:41 PM

PHP 배열의 데이터 유형은 스칼라 유형, 복합 유형 및 특수 유형의 세 가지 범주로 나뉩니다. 8개의 하위 범주는 다음과 같습니다. 1. 부울 유형, 2. 정수, 정수 유형, 부동 소수점 유형이라고도 함. as double; 4. 문자열, 배열; 6. 개체, 개체 8. NULL, 빈 null.

PHP에서 변수를 배열 유형으로 변환하는 방법 PHP에서 변수를 배열 유형으로 변환하는 방법 Feb 09, 2022 pm 05:52 PM

배열형으로 변환하는 방법: 1. 변환할 수치변수 앞에 괄호로 묶인 대상 유형 "(배열)"을 추가하고 구문은 "(배열) 변환변수"입니다. 2. settype() 함수를 사용합니다. 구문은 " settype(변환 변수,"배열")"입니다.

PHP 배열에는 여러 유형이 있습니다 PHP 배열에는 여러 유형이 있습니다 Jun 12, 2023 am 10:12 AM

PHP 배열에는 네 가지 유형이 있습니다. 1. 숫자 인덱스 배열, 각 요소에는 0부터 시작하여 증가하는 정수 첨자가 있습니다. 2. 각 요소에는 문자열 키가 있는 연관 배열; 배열, 모든 레벨의 다차원 배열을 생성할 수 있습니다. 4. 변수 키를 사용하여 배열을 사용하면 키-값 쌍의 배열을 동적으로 추가하고 삭제할 수 있습니다.

Golang 함수의 구조형과 배열형의 차이 분석 Golang 함수의 구조형과 배열형의 차이 분석 May 16, 2023 am 09:00 AM

Golang에서는 함수의 데이터 유형을 구조 유형과 배열 유형으로 나눌 수 있습니다. 이 두 유형에는 중요한 차이점이 있습니다. 이 기사에서는 차이점을 분석합니다. 1. 구조 유형 구조는 일부 필드로 구성된 데이터 유형입니다. 이러한 필드는 다양한 유형, 기본 유형 또는 기타 사용자 정의 유형일 수 있습니다. Golang에서는 "struct" 키워드를 사용하여 구조 유형을 정의한 다음 유형 이름을 사용하여 구조의 인스턴스를 만듭니다. 구조체는 점 표기법을 통해 해당 필드에 액세스할 수 있습니다.

PHP7.0에는 어떤 유형의 배열이 있습니까? PHP7.0에는 어떤 유형의 배열이 있습니까? May 27, 2023 pm 05:01 PM

PHP7.0에는 어떤 유형의 배열이 있습니까? 배열은 PHP7.0에서 매우 중요한 데이터 유형입니다. 여러 값을 저장할 수 있으며 이러한 값은 인덱스나 키를 통해 액세스할 수 있습니다. PHP 7.0에서 배열 유형은 매우 유연하므로 다양한 프로그래밍 문제를 해결하는 데 사용할 수 있습니다. 이번 글에서는 PHP7.0의 배열 타입과 사용법을 소개하겠습니다. 1. 일반 배열 일반 배열은 PHP7.0에서 가장 일반적인 유형 중 하나입니다. 이는 키-값 쌍의 순서가 지정된 목록으로 구성됩니다.

PHP의 배열 데이터 유형 탐색 및 조작 기술 PHP의 배열 데이터 유형 탐색 및 조작 기술 Jul 15, 2023 pm 07:37 PM

PHP에서 배열 데이터 유형의 탐색 및 조작 기술 PHP에서 배열은 관련 데이터 요소 그룹을 변수에 저장할 수 있도록 하는 매우 일반적으로 사용되는 데이터 유형입니다. 배열을 사용하면 인덱스나 관련 키를 통해 배열의 데이터에 액세스하고 조작할 수 있습니다. 이 기사에서는 PHP의 배열 탐색 및 조작 기술을 소개하고 참조용 샘플 코드를 제공합니다. 인덱스 배열 탐색 인덱스 배열은 자동으로 할당된 숫자를 인덱스로 사용하는 가장 일반적인 배열 유형입니다. for 루프나 for문을 사용할 수 있습니다.

사용자가 입력한 배열 유형을 찾는 C 프로그램 사용자가 입력한 배열 유형을 찾는 C 프로그램 Aug 30, 2023 am 10:29 AM

질문: 주어진 배열의 요소가 짝수, 홀수 또는 둘 다인지 확인하기 위해 검사해야 하는 배열 유형을 찾는 C 프로그램을 작성하세요. 해결 방법 사용자는 정수 배열을 입력한 다음 배열 유형을 표시해야 합니다. 예시 1 − 입력: 531, 출력: 홀수 배열. 예시 2 - 입력: 2468, 출력: 짝수 배열. 예시 3 - 입력: 12345, 출력: 혼합 배열. 알고리즘은 사용자가 입력한 배열 유형을 찾기 위해 아래에 주어진 알고리즘을 참조합니다. 1단계 - 런타임 시 배열의 크기를 읽습니다. 2단계−배열 요소를 입력합니다. 3단계 - 다음과 같이

See all articles