婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > Oracle定義聯(lián)合數(shù)組及使用技巧

Oracle定義聯(lián)合數(shù)組及使用技巧

熱門標(biāo)簽:北京外呼系統(tǒng)公司排名 溫州人工外呼系統(tǒng) 北京營銷外呼系統(tǒng)廠家 地圖標(biāo)注付款了怎么找不到了 沈陽400電話是如何辦理 貴陽智能電銷機(jī)器人官網(wǎng) 外呼系統(tǒng)口號(hào) 百度地圖標(biāo)注員是干什么 外呼系統(tǒng)鄭州
聯(lián)合數(shù)組以前被稱為PL/SQL表。在表中不能使用聯(lián)合數(shù)組,只能將它們用作程序設(shè)計(jì)的結(jié)構(gòu)體。只能在PL/SQL中訪問聯(lián)合數(shù)組。

注意到聯(lián)合數(shù)組帶來的一些關(guān)鍵問題是非常重要的。這些問題使我們介紹它們的用法時(shí),需要采取一些特別的方法。這些問題包括:

聯(lián)合數(shù)組不需要初始化,也沒有構(gòu)造函數(shù)語法。在對(duì)它們進(jìn)行賦值以前,也不需要專門為其分配存儲(chǔ)空間,也就不需要使用集合API的EXTEND方法。

在ORACLE 10G中,以及在ORACLE 10G以前的版本中,都可以使用數(shù)字索引聯(lián)合數(shù)組。另外,在ORACLE 10G中,還可以使用具有唯一性的變長字符串作為聯(lián)合數(shù)組的索引。

可以使用任意的整數(shù)作為聯(lián)合數(shù)組的索引,這就說明聯(lián)合數(shù)組的索引可以是任意正數(shù)、負(fù)數(shù)或0。
可以顯式地將等價(jià)的%ROWTYPE、記錄類型和對(duì)象類型的返回值,轉(zhuǎn)換成聯(lián)合數(shù)組的結(jié)構(gòu)體。

聯(lián)合數(shù)組是使用FORALL語句或BULK COLLECT子句的關(guān)鍵,而后者則允許數(shù)據(jù)庫到程序設(shè)計(jì)單元的批轉(zhuǎn)換。
在使用了全球化設(shè)置,例如NLS_COMP或NLS_SORT初始化參數(shù)的數(shù)據(jù)庫中,將字符串用作聯(lián)合數(shù)組索引的時(shí)候,需要我們進(jìn)行特殊的處理。

1、定義聯(lián)合數(shù)組和用作PL/SQL的程序結(jié)構(gòu)體
在PL/SQL語言中定義聯(lián)合數(shù)組的語法有兩種,一種是:
CREATE OR REPLACE TYPE type_name
AS TABLE OF element_type [NOT NULL]
INDEX BY [PLS_INTEGER | BINARY_INTEGER | VARCHAR2(size) ];
可以將正數(shù)、負(fù)數(shù)或者0值用作聯(lián)合數(shù)組的索引。ORACLE 10G中的PLS_INTEGER何BINARY_INTEGER類型都是不受限制的數(shù)據(jù)類型,這兩個(gè)數(shù)據(jù)類型都映射到C/C++、C#和JAVA的調(diào)用規(guī)范中。
變長字符串的最大長度為4000個(gè)字符。
另一種定義聯(lián)合數(shù)組的語法是:
CREATE OR REPLACE TYPE type_name
AS TABLE OF element_type [NOT NULL]
INDEX BY key_type;
其中的key_type允許我們使用VARCHAR2、STRING或LONG類型。使用VARCHAR2和STRING時(shí),都需要定義大小。使用LONG類型時(shí),則不需要定義大小,因?yàn)樗峭ㄟ^定義VARCHAR(32760)進(jìn)行定義的。
聯(lián)合數(shù)組不需要進(jìn)行初始化,也沒有構(gòu)造函數(shù)語法。這是與其他兩種集合類型(VARRAYS和嵌套表)有著本質(zhì)區(qū)別的地方。
如果你像下面這樣構(gòu)造一個(gè)聯(lián)合數(shù)組,那么會(huì)引發(fā)PLS-00222異常。
復(fù)制代碼 代碼如下:

-- Define an associative array of strings.
TYPE card_table IS TABLE OF VARCHAR2(5 CHAR)
INDEX BY BINARY_INTEGER;
-- and attempt to construct an associative array.
cards CARD_TABLE := card_table('A','B','C');
BEGIN
NULL;
END;

在前面的介紹中,我們知道對(duì)象的構(gòu)造函數(shù)是完全可以作為一個(gè)函數(shù)使用的。其他集合類型,例如VARRAYS和嵌套表,都是顯式定義構(gòu)造函數(shù)的對(duì)象類型。而聯(lián)合數(shù)組只是一個(gè)結(jié)構(gòu)體,不是一個(gè)對(duì)象類型。因此,它不能顯式地創(chuàng)建構(gòu)造函數(shù),也無法調(diào)用構(gòu)造函數(shù)。
2、聯(lián)合數(shù)組的初始化
前面已經(jīng)說過,我們可以將數(shù)字或者具有唯一性的變長字符串作為索引,構(gòu)造聯(lián)合數(shù)組。數(shù)字索引比如為整數(shù),可以為正整數(shù)、負(fù)整數(shù)和0值。唯一性的變長字符串可以是VARCHAR2、STRING或LONG數(shù)據(jù)類型。
1)以數(shù)字作為聯(lián)合數(shù)組索引
下面的例子給出了一個(gè)向以數(shù)字為索引的聯(lián)合數(shù)組中的元素賦值的過程,該示例示范了將VARRAY的內(nèi)容轉(zhuǎn)移到聯(lián)合數(shù)組的過程。
復(fù)制代碼 代碼如下:

-- Define a varray of twelve strings.
TYPE months_varray IS VARRAY(12) OF STRING(9 CHAR);
-- Define an associative array of strings.
TYPE calendar_table IS TABLE OF VARCHAR2(9 CHAR)
INDEX BY BINARY_INTEGER;
-- and construct a varray.
month MONTHS_VARRAY :=
months_varray('January','February','March'
,'April','May','June'
,'July','August','September'
,'October','November','December');
-- an associative array variable.
calendar CALENDAR_TABLE;
BEGIN
-- Check if calendar has no elements.
IF calendar.COUNT = 0 THEN
-- Print a title
DBMS_OUTPUT.PUT_LINE('Assignment loop:');
DBMS_OUTPUT.PUT_LINE('----------------');
-- Loop through all the varray elements.
FOR i IN month.FIRST..month.LAST LOOP
-- Initialize a null associative array element.
calendar(i) := '';
-- Print an indexed element from the associative array.
DBMS_OUTPUT.PUT_LINE(
'Index ['||i||'] is ['||calendar(i)||']');
-- Assign the numeric index valued varray element
-- to an equal index valued associative array element.
calendar(i) := month(i);
END LOOP;
-- Print a title
DBMS_OUTPUT.PUT(CHR(10));
DBMS_OUTPUT.PUT_LINE('Post-assignment loop:');
DBMS_OUTPUT.PUT_LINE('---------------------');
-- Loop through all the associative array elements.
FOR i IN calendar.FIRST..calendar.LAST LOOP
-- Print an indexed element from the associative array.
DBMS_OUTPUT.PUT_LINE(
'Index ['||i||'] is ['||calendar(i)||']');
END LOOP;
END IF;
END;
/

在第一個(gè)FOR-LOOP循環(huán)中,用等于VARRAY類型的month索引的一個(gè)索引值,為聯(lián)合數(shù)組類型的calendar變量賦上一個(gè)空值。這是為聯(lián)合數(shù)組分配空間的唯一方法。
2)以唯一字符串作為聯(lián)合數(shù)組索引
如下例所示:
復(fù)制代碼 代碼如下:

-- Define a varray of twelve variable length strings.
TYPE months_varray IS VARRAY(12) OF STRING(9 CHAR);
-- Define an associative array of variable length strings.
TYPE calendar_table IS TABLE OF VARCHAR2(9 CHAR)
INDEX BY VARCHAR2(9 CHAR);
-- and construct a varray.
month MONTHS_VARRAY :=
months_varray('January','February','March'
,'April','May','June'
,'July','August','September'
,'October','November','December');
-- an associative array variable.
calendar CALENDAR_TABLE;
BEGIN
-- Check if calendar has no elements.
IF calendar.COUNT = 0 THEN
-- Print a title
DBMS_OUTPUT.PUT_LINE('Assignment loop:');
DBMS_OUTPUT.PUT_LINE('----------------');
-- Loop through all the varray elements.
FOR i IN month.FIRST..month.LAST LOOP
-- Assign the numeric index valued varray element
-- to an equal index valued associative array element.
calendar(month(i)) := ''; --i;
-- Print an indexed element from the associative array.
DBMS_OUTPUT.PUT_LINE(
'Index ['||month(i)||'] is ['||i||']');
END LOOP;
-- Print a title
DBMS_OUTPUT.PUT(CHR(10));
DBMS_OUTPUT.PUT_LINE('Post-assignment loop:');
DBMS_OUTPUT.PUT_LINE('---------------------');
-- Loop through all the associative array elements.
FOR i IN calendar.FIRST..calendar.LAST LOOP
-- Print an indexed element from the associative array.
DBMS_OUTPUT.PUT_LINE(
'Index ['||i||'] is ['||calendar(i)||']');
END LOOP;
END IF;
END;

運(yùn)行上面這段代碼會(huì)出現(xiàn)錯(cuò)誤。ORA-06502:PL/SQL:numeric or value error:character to number convertion error。在第一個(gè)FOR-LOOP中的初始化是沒有任何問題的。可是在第二個(gè)FOR-LOOP循環(huán)中,程序試圖向計(jì)數(shù)器變量傳遞一個(gè)非數(shù)字的值。在上面的程序中,這個(gè)計(jì)數(shù)器變量是i。計(jì)數(shù)器變量的數(shù)據(jù)類型被定義為PLS_INTEGER類型。所以,就不能將整個(gè)變長字符串的索引值賦給一個(gè)整型變量—因?yàn)樽冮L字符串不是整數(shù)。這樣,自然就引發(fā)了類型轉(zhuǎn)換錯(cuò)誤ORA-06502。該示例之所以會(huì)引發(fā)錯(cuò)誤,是因?yàn)樵诔跏蓟?lián)合數(shù)組成員的時(shí)候,其中的計(jì)數(shù)器變量被轉(zhuǎn)換為VARCHAR2類型,而在讀聯(lián)合數(shù)組的時(shí)候,又將該計(jì)數(shù)器類型轉(zhuǎn)為INTEGER類型。
這其實(shí)給我們提出了一個(gè)新問題。非數(shù)字索引值需要我們明確的知道索引的開始值以及索引的遞增方法。集合API的FIRST何NEXT方法提供了這種工具。
如下例所示:
復(fù)制代碼 代碼如下:

-- Define variables to traverse an associative array that
-- uses variable length strings for index values.
current VARCHAR2(9 CHAR);
element INTEGER;
-- Define a varray of twelve variable length strings.
TYPE months_varray IS VARRAY(12) OF STRING(9 CHAR);
-- Define an associative array of variable length strings.
TYPE calendar_table IS TABLE OF VARCHAR2(9 CHAR)
INDEX BY VARCHAR2(9 CHAR);
-- and construct a varray.
month MONTHS_VARRAY :=
months_varray('January','February','March'
,'April','May','June'
,'July','August','September'
,'October','November','December');
-- an associative array variable.
calendar CALENDAR_TABLE;
BEGIN
-- Check if calendar has no elements.
IF calendar.COUNT = 0 THEN
-- Print a title
DBMS_OUTPUT.PUT_LINE('Assignment loop:');
DBMS_OUTPUT.PUT_LINE('----------------');
-- Loop through all the varray elements.
FOR i IN month.FIRST..month.LAST LOOP
-- Assign the numeric index valued varray element
-- to an equal index valued associative array element.
calendar(month(i)) := TO_CHAR(i);
-- Print an indexed element from the associative array.
DBMS_OUTPUT.PUT_LINE(
'Index ['||month(i)||'] is ['||i||']');
END LOOP;
-- Print a title
DBMS_OUTPUT.PUT(CHR(10));
DBMS_OUTPUT.PUT_LINE('Post-assignment loop:');
DBMS_OUTPUT.PUT_LINE('---------------------');
-- Loop through all the associative array elements.
FOR i IN 1..calendar.COUNT LOOP
-- Check if the first element in the loop.
IF i = 1 THEN
-- Assign the first character index to a variable.
current := calendar.FIRST;
-- Use the derived index to find the next index.
element := calendar(current);
ELSE
-- Check if next index value exists.
IF calendar.NEXT(current) IS NOT NULL THEN
-- Assign the character index to a variable.
current := calendar.NEXT(current);
-- Use the derived index to find the next index.
element := calendar(current);
ELSE
-- Exit loop since last index value is read.
EXIT;
END IF;
END IF;
-- Print an indexed element from the associative array.
DBMS_OUTPUT.PUT_LINE(
'Index ['||current||'] is ['||element||']');
END LOOP;
END IF;
END;

3、與BULK COLLECT和FORALL結(jié)合使用聯(lián)合數(shù)組
使用BULK COLLECT和FORALL胃我們打開了消除行級(jí)處理之門。使用BULK COLLECT可以獲取存儲(chǔ)在聯(lián)合數(shù)組或嵌套表中的記錄集。使用FORALL可以成批的發(fā)送DML語句。FORALL可以插入、更新和刪除數(shù)據(jù)。這些方法減少了PL/SQL引擎和SQL引擎之間來回切換上下文環(huán)境的次數(shù)。如果沒有這些方法,就會(huì)有太多的解析或取值過程。
你應(yīng)該還記得行級(jí)處理實(shí)際上使用的是%ROWTYPE和%TYPE。前者可以直接映射到記錄類型上。BULK COLLECT可以將%ROWTYPE或%TYPE類型的值的一個(gè)集合作為聯(lián)合數(shù)組或嵌套表的一個(gè)集合進(jìn)行賦值。FORALL提供了一種可以將聯(lián)合數(shù)組或嵌套表中的內(nèi)容轉(zhuǎn)移到數(shù)據(jù)庫對(duì)象的方法。
聯(lián)合數(shù)組和嵌套表集合類型可以與BULK COLLECT和FORALL結(jié)合使用。使用嵌套表時(shí),需要將嵌套表構(gòu)造為空元素的集合。BULK COLLECT會(huì)顯式地分配嵌套表的存儲(chǔ)空間。不需要對(duì)聯(lián)合數(shù)組進(jìn)行構(gòu)造,只要一個(gè)批賦值就可以了。同樣,聯(lián)合數(shù)組和嵌套表都可以作為SQL命令FORALL的源結(jié)構(gòu)。
如下示例所示:
復(fù)制代碼 代碼如下:

-- Create a table for the example.
CREATE TABLE bulk_numbers
(number_id NUMBER NOT NULL
,CONSTRAINT number_id_pk PRIMARY KEY (number_id));
-- Define an associative array of integers.
TYPE number_table IS TABLE OF bulk_numbers.number_id%TYPE
INDEX BY BINARY_INTEGER;
-- Define a variable of the associative array type.
number_list NUMBER_TABLE;
BEGIN
-- Loop from 1 to a million and increment associative array.
FOR i IN 1..10000 LOOP
-- Assign number value.
number_list(i) := i;
END LOOP;
-- Loop through all to do a bulk insert.
FORALL i IN 1..number_list.COUNT
INSERT
INTO bulk_numbers
VALUES (number_list(i));
-- Commit records.
COMMIT;
END;
-- Use a BULK COLLECT to retrieve a table into an
-- associative array.
-- Define an associative array of integers.
TYPE number_table IS TABLE OF bulk_numbers.number_id%TYPE
INDEX BY BINARY_INTEGER;
-- Define a variable of the associative array type.
number_list NUMBER_TABLE;
BEGIN
-- Check if calendar has no elements.
SELECT number_id
BULK COLLECT
INTO number_list
from bulk_numbers;
-- Print a title
DBMS_OUTPUT.PUT_LINE('Bulk Collected:');
DBMS_OUTPUT.PUT_LINE('---------------');
-- Loop through to print elements.
--只打印前兩條和最后兩條記錄
FOR i IN number_list.FIRST..number_list.LAST LOOP
-- Print only the first and last two.
IF i = 2 OR i >= 9999 THEN
-- Print an indexed element from the associative array.
DBMS_OUTPUT.PUT_LINE('Number ['||number_list(i)||']');
END IF;
END LOOP;
END;

在BULK COLLECT子句中使用了ORDER BY,保證得出的結(jié)果是按照數(shù)字升序排列的。如果不對(duì)元素進(jìn)行排序,就會(huì)發(fā)現(xiàn)它們是按照隨機(jī)的順序獲取的,而不是按它們的數(shù)字順序進(jìn)行獲取的。

標(biāo)簽:淮北 溫州 定西 潮州 通遼 衢州 包頭 衡水

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Oracle定義聯(lián)合數(shù)組及使用技巧》,本文關(guān)鍵詞  Oracle,定義,聯(lián)合,數(shù)組,及,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Oracle定義聯(lián)合數(shù)組及使用技巧》相關(guān)的同類信息!
  • 本頁收集關(guān)于Oracle定義聯(lián)合數(shù)組及使用技巧的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美一区二区黄色| 欧美一二三四在线| 国产精品麻豆网站| 粉嫩av亚洲一区二区图片| 欧美婷婷六月丁香综合色| 中文字幕精品在线不卡| 欧美制服丝袜第一页| 精品一区二区三区久久| 亚洲午夜一二三区视频| 国产精品日产欧美久久久久| 日韩精品一区在线| 7777精品伊人久久久大香线蕉| jlzzjlzz亚洲女人18| 黄色日韩网站视频| 青青草原综合久久大伊人精品优势| 一区二区三区四区在线播放| 国产精品入口麻豆九色| 国产精品亲子伦对白| 久久久久久9999| 欧美电影免费观看高清完整版在线观看 | 91一区在线观看| 蜜桃视频第一区免费观看| 亚洲成人免费在线| 精品99999| 欧美电影在线免费观看| 欧美视频精品在线| 欧美精品一级二级三级| 欧美人狂配大交3d怪物一区 | 亚洲色图欧洲色图婷婷| 亚洲欧洲三级电影| 国产精品欧美久久久久无广告 | 国产精品久久久久永久免费观看| 91在线视频在线| 亚洲色图视频网站| 亚洲精品写真福利| 亚洲综合999| 亚洲午夜在线视频| 日韩制服丝袜先锋影音| 秋霞电影一区二区| 国产精品一区久久久久| 成人av在线观| 欧美日韩一区二区电影| 日韩精品一区二区三区视频播放 | 亚洲精品在线网站| 中文字幕免费一区| 亚洲人成精品久久久久久| 亚洲影视资源网| 亚洲综合一区二区三区| 五月婷婷激情综合| 国产一区二区不卡在线| av亚洲产国偷v产偷v自拍| 欧美日韩精品一区二区三区四区| 日韩美女主播在线视频一区二区三区| 色婷婷久久99综合精品jk白丝 | 日韩福利电影在线观看| 精品一区二区三区视频在线观看| 成人伦理片在线| 在线电影院国产精品| 国产精品女人毛片| 麻豆一区二区三| 色成年激情久久综合| 日韩一区二区三区视频| 亚洲欧美日韩国产手机在线| 久久爱www久久做| 色婷婷精品大视频在线蜜桃视频| 欧美变态tickling挠脚心| 亚洲精品国产一区二区三区四区在线| 久久99精品久久久久久国产越南 | 中文字幕在线播放不卡一区| 日韩精品欧美精品| jlzzjlzz国产精品久久| 26uuu亚洲综合色| 亚洲国产日韩精品| 国产揄拍国内精品对白| 欧美三级一区二区| 91啪九色porn原创视频在线观看| 成人动漫视频在线| 丰满放荡岳乱妇91ww| 欧美肥妇free| 亚洲综合免费观看高清完整版在线| 亚洲狠狠爱一区二区三区| 99久久99久久精品免费看蜜桃| 精品福利在线导航| 蜜臀va亚洲va欧美va天堂| www.日韩精品| 欧美国产1区2区| 亚洲福利视频导航| 91搞黄在线观看| 亚洲三级免费电影| www.亚洲免费av| 国产精品乱人伦| 国产精品亚洲一区二区三区在线| 欧美性xxxxx极品少妇| 亚洲精品视频在线观看网站| www.亚洲免费av| 不卡影院免费观看| 成人av资源网站| 国产欧美日韩综合| 国内成+人亚洲+欧美+综合在线| 欧洲av一区二区嗯嗯嗯啊| 亚洲猫色日本管| 99精品国产91久久久久久| 国产亚洲自拍一区| 日韩中文字幕不卡| 亚洲午夜精品在线| 国产在线播放一区二区三区| 蜜桃视频第一区免费观看| 亚洲理论在线观看| 精品久久一区二区| 日韩女优电影在线观看| www.亚洲免费av| 91精品国产色综合久久不卡电影| 欧美日韩国产精品成人| 国产欧美视频一区二区三区| 日韩精彩视频在线观看| 国产一区二三区| av电影天堂一区二区在线| 免播放器亚洲一区| 欧美国产乱子伦| 亚洲电影激情视频网站| 国产永久精品大片wwwapp| 91在线播放网址| 色中色一区二区| 久久夜色精品国产噜噜av | 亚洲品质自拍视频| 免费看日韩精品| 色婷婷精品大视频在线蜜桃视频| 国产精品久久久久影院色老大| 精品无码三级在线观看视频| 欧美日韩综合不卡| 亚洲柠檬福利资源导航| 91一区二区在线| 亚洲欧洲99久久| 91在线国内视频| ...中文天堂在线一区| 成人毛片视频在线观看| 91精品国产综合久久福利| 亚洲欧洲国产专区| 狠狠色丁香婷婷综合久久片| 日韩一区二区三区四区| 免费美女久久99| 精品国产一区二区亚洲人成毛片| 天堂久久一区二区三区| 欧美精品一级二级三级| 免费黄网站欧美| 日韩精品一区国产麻豆| 久久 天天综合| 久久精品男人天堂av| 国产河南妇女毛片精品久久久| 久久色中文字幕| 成人动漫一区二区三区| 亚洲视频免费观看| 欧美日韩你懂得| 久久精品噜噜噜成人av农村| 2020国产精品自拍| 国产激情精品久久久第一区二区| 亚洲精品伦理在线| 成人国产在线观看| 欧美日韩国产一二三| 亚洲一线二线三线久久久| 欧美日本在线看| 亚洲一区在线观看免费观看电影高清| 欧美三级电影网站| 美女免费视频一区二区| 国产福利一区在线| ...av二区三区久久精品| 欧美中文字幕亚洲一区二区va在线 | 亚洲自拍都市欧美小说| 欧美色综合久久| 韩国三级中文字幕hd久久精品| 精品久久一区二区三区| 免费在线观看成人| 国产精品福利在线播放| 欧美精品一二三| 成人激情免费电影网址| 亚洲国产精品久久艾草纯爱| 欧美videos中文字幕| 精品一二三四区| 精品盗摄一区二区三区| 国产成人免费在线观看| 自拍偷自拍亚洲精品播放| 欧美日韩国产免费一区二区| 美女mm1313爽爽久久久蜜臀| 欧美极品少妇xxxxⅹ高跟鞋| 欧美午夜在线一二页| 精品午夜久久福利影院| 亚洲国产高清在线| 777久久久精品| 99国产精品国产精品毛片| 五月开心婷婷久久| 久久久久久99精品| 91精品国产入口| 成人性生交大片免费看视频在线 | 亚洲丝袜另类动漫二区| av成人老司机| 日韩精品乱码免费| 亚洲日本在线看| 国产日韩欧美精品电影三级在线| 99精品热视频| 国产精品一二三四区|