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

主頁 > 知識庫 > Oracle定義聯合數組及使用技巧

Oracle定義聯合數組及使用技巧

熱門標簽:北京外呼系統公司排名 溫州人工外呼系統 北京營銷外呼系統廠家 地圖標注付款了怎么找不到了 沈陽400電話是如何辦理 貴陽智能電銷機器人官網 外呼系統口號 百度地圖標注員是干什么 外呼系統鄭州
聯合數組以前被稱為PL/SQL表。在表中不能使用聯合數組,只能將它們用作程序設計的結構體。只能在PL/SQL中訪問聯合數組。

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

聯合數組不需要初始化,也沒有構造函數語法。在對它們進行賦值以前,也不需要專門為其分配存儲空間,也就不需要使用集合API的EXTEND方法。

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

可以使用任意的整數作為聯合數組的索引,這就說明聯合數組的索引可以是任意正數、負數或0。
可以顯式地將等價的%ROWTYPE、記錄類型和對象類型的返回值,轉換成聯合數組的結構體。

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

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

-- 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;

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

-- 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;
/

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

-- 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;

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

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

-- 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,保證得出的結果是按照數字升序排列的。如果不對元素進行排序,就會發現它們是按照隨機的順序獲取的,而不是按它們的數字順序進行獲取的。

標簽:淮北 溫州 定西 潮州 通遼 衢州 包頭 衡水

巨人網絡通訊聲明:本文標題《Oracle定義聯合數組及使用技巧》,本文關鍵詞  Oracle,定義,聯合,數組,及,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Oracle定義聯合數組及使用技巧》相關的同類信息!
  • 本頁收集關于Oracle定義聯合數組及使用技巧的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    一区二区三区四区精品在线视频| 亚洲人成电影网站色mp4| 中文字幕欧美一区| 99久久99久久免费精品蜜臀| 亚洲精品一区二区三区香蕉| 日韩精品色哟哟| 精品国产91久久久久久久妲己 | 中文字幕精品在线不卡| 国产激情一区二区三区| 欧美激情中文不卡| 99re成人在线| 日本成人在线电影网| 精品国偷自产国产一区| 成人国产亚洲欧美成人综合网 | 欧美成人高清电影在线| 久久久久高清精品| 亚洲妇熟xx妇色黄| 久久精品视频免费| 欧美精品三级在线观看| 蜜桃视频在线观看一区二区| 久久久久国产成人精品亚洲午夜| 国产99久久久久久免费看农村| 蜜乳av一区二区三区| 波多野结衣亚洲一区| 91福利国产成人精品照片| 狠狠色丁香久久婷婷综合丁香| 中文字幕一区二区三区av| 欧美高清性hdvideosex| 成年人午夜久久久| 奇米影视一区二区三区| 亚洲精品一二三| 国产亚洲视频系列| 2021国产精品久久精品| 欧美性欧美巨大黑白大战| 国产不卡视频一区二区三区| 美女尤物国产一区| 午夜精品福利视频网站| 亚洲黄网站在线观看| 亚洲欧洲三级电影| 亚洲靠逼com| 国产精品蜜臀av| 国产亚洲综合在线| 欧美激情在线一区二区| 欧美精品一区视频| 26uuu色噜噜精品一区二区| 精品国产一区二区三区久久久蜜月| 在线视频亚洲一区| 欧美日韩一区高清| 日韩区在线观看| 欧美本精品男人aⅴ天堂| 日韩视频在线观看一区二区| 91亚洲午夜精品久久久久久| 国产精品热久久久久夜色精品三区| 国产精品一二三在| 一区二区三区四区五区视频在线观看| 99久久99久久精品国产片果冻| 亚洲免费观看高清完整版在线观看| 中文字幕一区二区三区视频| 亚洲一区在线观看免费| 国内精品国产三级国产a久久| av色综合久久天堂av综合| 欧美日韩亚洲不卡| 国产日本欧美一区二区| 欧美精品色综合| 亚洲精品网站在线观看| 激情av综合网| 色视频欧美一区二区三区| 日韩欧美国产一区在线观看| 欧美在线视频你懂得| 粉嫩av亚洲一区二区图片| 日本高清无吗v一区| 精品成人一区二区| 三级久久三级久久| 色欧美日韩亚洲| 亚洲色图制服诱惑 | 91精品国产一区二区| 国产精品久久久久久久久晋中| 丝袜美腿亚洲一区| 一本色道久久综合狠狠躁的推荐| 日韩三级视频中文字幕| 香港成人在线视频| 欧美日韩亚洲综合在线| 亚洲精品免费在线| 91尤物视频在线观看| 亚洲色图丝袜美腿| www.成人网.com| 中文字幕制服丝袜一区二区三区| 国模娜娜一区二区三区| 欧美精品一二三| 蜜桃久久久久久久| 欧美一级高清大全免费观看| 日韩成人精品在线| 欧美国产日产图区| 成人av集中营| 中文字幕色av一区二区三区| 欧美日韩中文字幕一区| 精品一区二区免费在线观看| 中文字幕永久在线不卡| 精品视频在线免费观看| 美国av一区二区| 国产欧美一区二区精品性| 热久久免费视频| 欧美性色黄大片| 国产精品久久久久一区二区三区 | 伊人开心综合网| 国产成人免费av在线| 精品国产一区二区在线观看| 亚洲最新视频在线观看| 91小视频在线| 中文字幕一区二区三区四区不卡| 激情图片小说一区| 欧美一卡2卡三卡4卡5免费| 亚洲一级二级在线| 在线免费观看不卡av| 国产精品久久久久影视| 成人污视频在线观看| 中文一区在线播放 | 亚洲国产成人精品视频| 欧美亚洲综合一区| 首页亚洲欧美制服丝腿| 欧美理论片在线| 精品无人区卡一卡二卡三乱码免费卡| 色又黄又爽网站www久久| 亚洲美女免费在线| 欧美日韩精品福利| 国产精品99精品久久免费| 日本aⅴ亚洲精品中文乱码| 成人夜色视频网站在线观看| 亚洲色图欧洲色图婷婷| 欧美无人高清视频在线观看| 日韩精品乱码免费| 久久免费电影网| 在线观看三级视频欧美| 美国十次了思思久久精品导航| 久久婷婷综合激情| 色先锋aa成人| 国产麻豆精品一区二区| 亚洲精品少妇30p| 精品1区2区在线观看| www.色精品| 极品少妇一区二区三区精品视频| 国产精品久久久久久久久动漫| 欧美特级限制片免费在线观看| 久久国产精品第一页| 亚洲午夜免费视频| 亚洲人妖av一区二区| 精品剧情在线观看| 欧美一二三区精品| 欧美午夜不卡在线观看免费| 成人禁用看黄a在线| 国产乱子伦视频一区二区三区| 日韩制服丝袜先锋影音| 洋洋成人永久网站入口| 夜夜夜精品看看| 亚洲三级久久久| 最新国产の精品合集bt伙计| 欧美一级免费大片| 欧美精品一区二区久久婷婷 | 欧美日韩夫妻久久| 欧美日韩高清不卡| 日韩美女一区二区三区| 日韩亚洲电影在线| 国产精品久久久久7777按摩| 久久精品视频在线免费观看| 国产精品午夜久久| 一区二区高清免费观看影视大全| 亚洲青青青在线视频| 日韩电影免费在线看| 国产a精品视频| 欧美一区二区精品久久911| 欧美不卡一区二区三区| 亚洲国产成人在线| 亚洲图片欧美视频| av电影在线观看一区| 制服丝袜激情欧洲亚洲| 亚洲乱码国产乱码精品精的特点 | 欧美精品亚洲一区二区在线播放| 欧美一区日韩一区| 亚洲久草在线视频| 东方欧美亚洲色图在线| 91.成人天堂一区| 亚洲品质自拍视频| 成人国产精品免费网站| 日韩精品一区二区三区视频在线观看 | 日韩精品一二三四| 91福利在线播放| 亚洲精品视频在线观看网站| 国产精一区二区三区| 精品国产一区二区三区忘忧草| 性感美女久久精品| 欧洲精品一区二区三区在线观看| 成人免费视频网站在线观看| 91网站最新地址| 一区二区三区中文字幕电影| 国产91高潮流白浆在线麻豆| 亚洲国产精品国自产拍av| 高清不卡一区二区在线| 亚洲乱码中文字幕综合| 欧美日韩一区小说| 免费美女久久99|