Maison base de données tutoriel 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;

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quels sont les types de tableaux php ? Quels sont les types de tableaux php ? Jun 01, 2023 am 10:41 AM

Il existe deux types de tableaux PHP, à savoir : 1. Tableau d'index, l'indice est constitué de nombres, commençant à 0 par défaut, chaque chiffre correspond à la position d'un élément du tableau dans le tableau 2. Tableau associatif, l'indice est constitué de ; valeurs numériques et caractères Il est composé d'un mélange de chaînes. Si un nom de clé dans un tableau n'est pas un nombre, alors le tableau est un tableau associatif.

Combien de types de données y a-t-il dans le tableau php Combien de types de données y a-t-il dans le tableau php Jun 06, 2023 pm 03:41 PM

Les types de données dans les tableaux PHP sont divisés en trois catégories : type scalaire, type composite et type spécial. Les huit sous-catégories sont : 1. booléen, type booléen 2. entier, type entier 3. flottant, type à virgule flottante, également connu ; as As double ; 4. chaîne, chaîne ; 5. tableau, tableau ; 6. objet, objet ; 7. ressource, type de ressource ;

Comment convertir une variable en type tableau en php Comment convertir une variable en type tableau en php Feb 09, 2022 pm 05:52 PM

Méthode de conversion en type tableau : 1. Ajoutez le type cible "(tableau)" entre parenthèses avant la variable numérique à convertir, et la syntaxe est "(tableau) variable de conversion" 2. Utilisez la fonction settype(), la syntaxe est " settype(conversion variable,"array")".

Il existe plusieurs types de tableaux php Il existe plusieurs types de tableaux php Jun 12, 2023 am 10:12 AM

Il existe quatre types de tableaux PHP, à savoir : 1. Tableau d'index numérique, dont chaque élément a un indice entier, commençant à 0 et croissant ; 2. Tableau associatif, dont chaque élément a une chaîne Key ; tableau, vous pouvez créer des tableaux multidimensionnels de n'importe quel niveau ; 4. Tableau avec des clés variables, vous pouvez ajouter et supprimer dynamiquement des tableaux de paires clé-valeur.

Analyse de la différence entre le type de structure et le type de tableau de la fonction Golang Analyse de la différence entre le type de structure et le type de tableau de la fonction Golang May 16, 2023 am 09:00 AM

Dans Golang, les types de données des fonctions peuvent être divisés en types de structure et types de tableaux. Il existe des différences importantes entre ces deux types. Cet article analysera leurs différences. 1. Type de structure Une structure est un type de données composé de quelques champs. Ces champs peuvent être de différents types, de types de base ou d'autres types personnalisés. Dans Golang, utilisez le mot-clé « struct » pour définir un type de structure, puis utilisez le nom du type pour créer une instance de la structure. Une structure peut accéder à ses champs via la notation par points, ou

Quels types de tableaux existe-t-il dans PHP7.0 ? Quels types de tableaux existe-t-il dans PHP7.0 ? May 27, 2023 pm 05:01 PM

Quels types de tableaux existe-t-il dans PHP7.0 ? Le tableau est un type de données très important dans PHP7.0. Il peut stocker plusieurs valeurs et ces valeurs sont accessibles via un index ou une clé. En PHP 7.0, les types de tableaux sont très flexibles et peuvent donc être utilisés pour résoudre de nombreux problèmes de programmation différents. Dans cet article, nous présenterons les types de tableaux dans PHP7.0 et comment les utiliser. 1. Tableaux ordinaires Les tableaux ordinaires sont l'un des types les plus courants dans PHP7.0. Il consiste en une liste ordonnée de paires clé-valeur, où

Compétences de traversée et d'exploitation des types de données de tableau en PHP Compétences de traversée et d'exploitation des types de données de tableau en PHP Jul 15, 2023 pm 07:37 PM

Compétences de traversée et d'exploitation des types de données tableau en PHP En PHP, le tableau est un type de données très couramment utilisé qui nous permet de stocker un groupe d'éléments de données associés dans une variable. À l'aide de tableaux, nous pouvons accéder et manipuler les données du tableau via des index ou des clés associées. Cet article présentera les techniques de traversée de tableaux et de manipulation en PHP et fournira des exemples de code pour référence. Parcours de tableaux indexés Les tableaux indexés sont le type de tableau le plus courant qui utilise des nombres automatiquement attribués comme index. Nous pouvons utiliser for loop ou fore

Programme C pour trouver le type de tableau entré par l'utilisateur Programme C pour trouver le type de tableau entré par l'utilisateur Aug 30, 2023 am 10:29 AM

Question : Écrivez un programme C pour trouver le type de tableau qui doit être vérifié pour déterminer si les éléments d'un tableau donné sont pairs ou impairs, ou les deux. Solution L'utilisateur doit saisir un tableau d'entiers, puis afficher le type du tableau. Exemple 1 - Entrée : 531, sortie : tableau impair. Exemple 2 - Entrée : 2468, sortie : tableau pair. Exemple 3 - Entrée : 12345, sortie : tableau mixte. L'algorithme fait référence à l'algorithme donné ci-dessous pour trouver le type de tableau saisi par l'utilisateur. Étape 1 - Lisez la taille du tableau au moment de l'exécution. Étape 2 - Saisissez les éléments du tableau. Étape 3 - comme

See all articles