精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

用DB2 pureXML執行不區分大小寫的高效搜索

數據庫 數據庫運維
本文解釋如何使用 DB2® pureXML™ 創建不區分大小寫的數據庫以及讓 XML 查詢和 XML 索引發揮預期的作用。

根據定義,XML 元素和屬性的值是區分大小寫的。例如,如果搜索值為 “Paris” 的 元素,那么不會找到 “PARIS” 或 “paris”。可以使用 fn:upper-case() 等 XQuery 函數解決這個問題,但是使用這些函數時不能使用 XML 索引,所以性能可能不好。本文解釋如何使用 DB2® pureXML™ 創建不區分大小寫的數據庫以及讓 XML 查詢和 XML 索引發揮預期的作用。用大寫和小寫函數執行不區分大小寫的搜索

下面的示例幫助您更清楚地理解不區分大小寫的搜索。清單 1 定義一個包含一個 INTEGER 列和一個 XML 列的表,并在表中插入 7 行。每行包含一個小的客戶文檔,其中包含 XML 元素

此元素中的值在大小寫方面并不一致。一些值是全大寫的,一些是全小寫的,其他是大小寫混合的(首字母大寫)。如果數據來自不同的應用程序,而這些應用程序采用不同的大小寫數據輸入規則,就會出現這種情況。

清單 1. 示例表和數據

CREATE TABLE customer (id INTEGER, xmldoc XML);

INSERT INTO customer (id, xmldoc)
VALUES (1,'<Customer id="1"><city>PARIS</city></Customer>'),
       (2,'<Customer id="2"><city>Tokyo</city></Customer>'),
       (3,'<Customer id="3"><city>tokyo</city></Customer>'),
       (4,'<Customer id="4"><city>PARIS</city></Customer>'),
       (5,'<Customer id="5"><city>paris</city></Customer>'),
       (6,'<Customer id="6"><city>Delhi</city></Customer>'),
       (7,'<Customer id="7"><city>Paris</city></Customer>'); 

如果一個應用程序查詢這些 XML 文檔,尋找某一城市的客戶,那么很可能需要不區分大小寫的搜索。例如,可能希望找到 Paris 的所有客戶,也就是希望獲取第 1、4、5 和 7 行。但是,如果搜索值 “Paris”,那么只會返回第 7 行。要想獲取所需的所有四行,可以使用 XQuery 函數 fn:upper-case() 把 city 元素值轉換為大寫并與 “PARIS” 做比較。清單 2 中的查詢就采用這種方式,它會返回 Paris 的所有四個客戶。

清單 2. 選擇 Paris 的客戶

    
SELECT id, XMLCAST( XMLQUERY('$XMLDOC/Customer/city') AS VARCHAR(15)) AS city
FROM customer
WHERE XMLEXISTS('$XMLDOC/Customer[fn:upper-case(city) = "PARIS"]');

如果查詢通過一個參數標志提供搜索值,那么這個參數也應該轉換為大寫,見 清單 3。這個參數標志(“?”)的類型為 VARCHAR(15) 并作為變量 “c” 傳遞給 XQuery 謂詞。

清單 3. 使用參數標志選擇客戶

   
SELECT id, XMLCAST( XMLQUERY('$XMLDOC/Customer/city') AS VARCHAR(15)) AS city
FROM customer
WHERE XMLEXISTS('$XMLDOC/Customer[fn:upper-case(city) = fn:upper-case($c)]'
                 PASSING CAST(? AS VARCHAR(15)) AS "c");


圖 1 顯示以上示例查詢的輸出。

圖 1. 示例查詢的結果

如果只查詢少量數據,或者查詢還包含其他選擇性謂詞,使得大寫謂詞只應用于很小的中間結果集,那么這種方式效果還不錯。問題是如果使用包含 fn:upper-case() 函數的謂詞,就不會使用 DB2 中的 XML 索引。因此,這種方式不適用于大量數據。

要想避免使用 fn:upper-case() 函數并利用 XML 索引加快查詢,就需要創建不區分大小寫的數據庫。

創建不區分大小寫的 DB2 數據庫

DB2 從 Version 9.5 Fixpack 1 開始支持感知地區的 Unicode 排序規則。這使我們能夠忽略大小寫和/或重音符號。要想創建對于所有字符串比較不區分大小寫的數據庫,需要使用排序規則 UCA500R1,見 清單 4。

清單 4. 創建不區分大小寫的數據庫

   
CREATE DATABASE testdb
USING CODESET UTF-8 TERRITORY US
COLLATE USING UCA500R1_LEN_S2;

字符串 UCA500R1_LEN_S2 究竟意味著什么?UCA500R1 指定此數據庫使用基于 Unicode 5.0.0 標準的默認 Unicode Collation Algorithm(UCA)。因為默認的 UCA 不能同時覆蓋 Unicode 支持的每種語言的排序規則序列,所以可以使用可選屬性定制字符的次序。屬性以下劃線(_)分隔。UCA500R1 關鍵字加上所有屬性構成一個 UCA 排序規則名。

清單 4 中使用的排序規則名包含兩個屬性:LEN 和 S2。LEN 是 L(語言)和 EN(英語的 ISO 639-1 語言編碼)的組合。第二個屬性 S2 指定強度級別,這決定在字符串排序或比較時是否考慮大小寫或重音符號。在 清單 4 中使用強度級別 2,所以 “PARIS” 和 “paris” 是相等的。下面是其他有效值的示例:

UCA500R1_LEN_S1 導致 "cliche" = "Cliche" = "cliché"

UCA500R1_LEN_S2 導致 "cliche" = "Cliche" < "cliché"

UCA500R1_LEN_S3 導致 "cliche" < "Cliche" < "cliché"

在 DB2 Information Center 中可以找到可以作為 UCA 排序規則名的所有組合(參見 參考資料)。

在不區分大小寫的數據庫中查詢 XML 數據

因為此數據庫使用排序規則名 UCA500R1 和強度級別 2,所以現在可以簡化前面的查詢,去掉 fn:upper-case() 函數(清單 5),就像所有數據都是大寫的一樣。無論搜索字符串是 “Paris” 或 “PARIS” 還是其他任何大小寫組合,結果都是相同的。

清單 5. 選擇 Paris 的客戶

   
SELECT id, XMLCAST( XMLQUERY('$XMLDOC/Customer/city') AS VARCHAR(15)) AS city
FROM customer
WHERE XMLEXISTS('$XMLDOC/Customer[city = "PARIS"]');


圖 2. 示例查詢的結果

 
 

如果通過添加 ORDER BY 子句按提取的 city 值排序,那么結果集仍然是相同的:PARIS、paris 和 Paris 被當作相同的值。

為了高效地查詢此數據,尤其是在表中行數很大的情況下,應該用 XPath /Customer/city 創建一個 XML 索引,見 清單 6:

清單 6. 創建 XML 索引

   
  
CREATE INDEX customer_lang_idx ON test (xmldoc)
       GENERATE KEY USING XMLPATTERN '/Customer/city' AS SQL VARCHAR(15);

現在,如果用 Visual Explain 或 db2exfmt 解釋此查詢,就會看到這個不區分大小寫的搜索使用了索引:

圖 3. 在不區分大小寫的數據庫中查詢 Paris 的所有客戶的 Explain Plan

本節介紹的方法有一個潛在的缺點:整個數據庫中所有表中的所有列中的所有數據都是不區分大小寫的。不可能以區分大小寫的方式處理特定的表或列。要么都區分大小寫,要么都不區分。

注意,不區分大小寫只應用于元素和屬性值,而不應用于標記名本身。XML 標記和路徑表達式仍然是區分大小寫的。例如,XPath 表達式 /Customer/city(小寫 “c”)和 /Customer/City(大寫 “C”)是不同的。后者不匹配示例數據中的任何元素,因為示例數據中的 元素名是小寫的。

性能

在數據庫中使用定制的排序規則可能影響查詢性能,因為在選擇更寬松的 UCA 設置時,匹配的字符串數量可能會增加。換句話說,在不區分大小寫的數據庫中,字符串比較的開銷可能會略微增加。為了查明區分大小寫的和不區分大小寫的數據庫之間的性能差異,我們創建了一個常規數據庫(區分大小寫)和一個不區分大小寫的數據庫。然后,插入來自 TPoX 基準測試的 20,000 個 CustAcc 文檔并在這兩個數據庫中對各種查詢進行測試。

對于只涉及少量到中等數量的行的查詢,兩個測試數據庫之間的性能差異可以忽略不計。我們發現涉及大量行的查詢的性能差異比較大,比如對所有 20,000 個 XML 文檔進行全表掃描并對每個文檔比較字符串。在不區分大小寫的數據庫中,這種查詢花費的時間增加了 5% 到 8%。因此,實現不區分大小寫的搜索需要付出的代價并不大。

結束語

以不區分大小寫的方式搜索 DB 2 數據有多種方法,比如使用生成的列(請參見 參考資料)。盡管這些方法都適合關系數據,但是不適合查詢 XML 數據。以不區分大小寫的方式處理 XML 數據的最佳方法是用定制的 Unicode 排序規則創建數據庫。這使數據庫中的所有字符串值比較都采用不區分大小寫的方式,避免妨礙使用 XML 索引和關系索引。由于不區分大小寫或重音符號,會增加匹配的字符串,但是增加的開銷非常低。

【編輯推薦】

  1. Oracle數據庫中段管理的四個技巧
  2. 最簡單刪除SQL Server中所有數據的方法
  3. DB 2數據庫性能優化技巧詳解
責任編輯:彭凡 來源: IBM
相關推薦

2011-11-30 21:46:24

ibmdwDB2 pureXML

2009-01-18 16:33:09

pureXMLDB2 pureXMLXML

2010-08-20 12:49:49

DB2 pureXML

2009-03-10 10:31:26

DB2XMLpureXML

2009-09-22 12:25:04

ibmdwDB2

2010-08-09 17:52:38

DB2 pureXML

2009-04-17 10:07:42

2009-11-23 19:57:01

ibmdwDB2

2011-08-30 10:10:30

UbuntuLinuxMySQL

2010-11-01 11:45:06

DB2管理頁大小

2010-11-03 11:26:39

DB2表空間

2010-06-04 20:04:10

MySQL數據庫大小寫

2010-09-07 16:11:19

執行DB2命令

2010-11-01 17:02:52

DB2頁大小

2010-08-19 13:59:01

DB2命令

2010-11-25 16:09:58

mysql查詢大小寫

2010-07-28 10:13:06

DB2查詢Table

2010-08-26 10:17:31

DB2.NET開發

2011-05-07 10:47:29

Oracle大小寫

2021-06-15 09:39:45

Oracle敏感數據庫
點贊
收藏

51CTO技術棧公眾號

久久99亚洲热视| 精品美女在线观看| 亚洲一一在线| www天堂在线| 乱码第一页成人| 精品国偷自产在线视频| 国产二级一片内射视频播放| 久久久久久久性潮| 偷拍与自拍一区| 伊人天天久久大香线蕉av色| 日韩一级免费视频| 久久国产三级精品| 午夜精品三级视频福利| 99久久99久久精品免费| 国产一区二区三区不卡av| 欧美色精品天天在线观看视频| 免费的一级黄色片| av在线免费观看网站| 成人午夜在线免费| 国产精品亚发布| 天天操天天干视频| 在线看片不卡| 中文字幕欧美日韩在线| 性色av蜜臀av色欲av| 国产日韩在线观看视频 | 欧美日韩国产精品综合| 精品日本12videosex| 亚洲国产精品系列| 麻豆网站免费观看| 国外成人福利视频| 色婷婷综合久久久中文字幕| www插插插无码视频网站| 国产人成网在线播放va免费| 中文字幕精品三区| 久久五月天婷婷| 好吊色一区二区三区| 国产精品一区2区| 国产在线98福利播放视频| 无码人妻丰满熟妇精品区| 亚洲国产免费看| 欧美俄罗斯乱妇| 91杏吧porn蝌蚪| 欧美成人精品一区二区三区在线看| 日韩黄色在线免费观看| 成人在线视频免费播放| 成人h动漫精品一区二区器材| 91精品免费观看| 在线观看免费不卡av| 欧美国产日韩电影| 欧美亚洲高清一区| 男女爽爽爽视频| 成人勉费视频| 91高清在线观看| 四虎永久在线精品无码视频| 欧美黑人巨大xxxxx| 一本色道久久综合亚洲91| 国产一区二区三区精彩视频| 是的av在线| 一本一道久久a久久精品| 国产精品亚洲二区在线观看| 日韩性xxx| 欧美亚洲国产一区二区三区va| 九一精品在线观看| 日韩毛片免费看| 欧美一卡二卡在线| 色欲欲www成人网站| 风间由美一区二区av101| 亚洲丁香久久久| 黄色国产在线观看| 欧美日韩中字| 久久久国产一区| 麻豆精品一区二区三区视频| 国产一区视频在线观看免费| 久久99亚洲精品| 日韩毛片在线播放| 久久久xxx| 国产主播欧美精品| 人妻一区二区三区免费| 久久综合久久鬼色中文字| 日韩国产欧美一区| 久草资源在线观看| 亚洲h动漫在线| 国产又黄又猛视频| 国产激情一区| 日韩成人在线视频| 欧美亚洲色综久久精品国产| 欧美激情四色| 国产成人av在线播放| 一级全黄少妇性色生活片| 高潮精品一区videoshd| 精品欧美日韩在线| 日本精品在线| 午夜精品久久久久影视| 国产理论在线播放| 成人看片爽爽爽| 一区二区三区在线播放欧美| 五月天丁香激情| 老牛嫩草一区二区三区日本| 99高清视频有精品视频| 国产在线色视频| 亚洲综合区在线| 色婷婷综合久久久久中文字幕| 日韩在线观看中文字幕| 国产亚洲欧美另类中文| 久久久国产精品黄毛片| 蜜桃视频在线一区| 成人动漫在线视频| 午夜小视频在线| 欧美日韩一区二区免费视频| 99九九精品视频| 国产成人精品一区二区免费看京| 欧美精品免费播放| 销魂美女一区二区| 成人av中文字幕| 影音先锋成人资源网站| 日本肉肉一区| 精品亚洲一区二区三区在线播放 | 在线中文字幕一区| 亚洲无人区码一码二码三码| 99热国内精品| 国产精品视频一区二区高潮| 色欲av伊人久久大香线蕉影院| 国产精品久久久久影院老司| 欧美成人黑人猛交| 国产精品xxxav免费视频| 日日狠狠久久偷偷四色综合免费| 国产成人精品网| 成人黄色网址在线观看| 污污污污污污www网站免费| 涩涩涩久久久成人精品| 亚洲无亚洲人成网站77777| 国产又爽又黄的视频| 成人久久视频在线观看| 精品无码av无码免费专区| 台湾佬中文娱乐久久久| 精品亚洲永久免费精品| 久久草视频在线| 成人免费视频免费观看| 人妻av无码专区| 亚洲精品一二三**| 欧美成人午夜剧场免费观看| 夜夜爽8888| 国产精品欧美一区喷水| 欧美日韩中文不卡| 日韩精品诱惑一区?区三区| 日本最新高清不卡中文字幕| 日韩av视屏| 欧美性xxxx极品高清hd直播| 亚洲精品乱码久久久久久久| 宅男噜噜噜66国产日韩在线观看| 国产日韩在线一区二区三区| 国产白浆在线免费观看| 亚洲国产欧美一区二区丝袜黑人| 国产精品.www| 久久影视一区二区| 日韩网址在线观看| 久久av资源| 国产日韩欧美影视| 91国内在线| 亚洲国产精品人久久电影| 亚洲永久精品在线观看| 久久久www成人免费无遮挡大片| 91香蕉视频污版| 91亚洲一区| 亚洲最大成人在线| 鲁鲁在线中文| 在线观看日韩av| 亚洲一区二区人妻| 一区二区三区在线观看国产| 国产人成视频在线观看| 久久先锋影音| 正在播放国产精品| 午夜免费欧美电影| 欧美一级视频免费在线观看| av在线电影播放| 欧美一区二区三区免费大片| 日韩aaaaaa| 国产欧美视频一区二区三区| 999热精品视频| 夜夜精品视频| 亚洲精品在线观看免费| 亚洲日本va午夜在线电影| 欧美一区二区三区图| 日本不卡视频| 亚洲第一精品福利| 成年人晚上看的视频| 亚洲女同女同女同女同女同69| 50一60岁老妇女毛片| 蜜桃久久av一区| 日本男女交配视频| 欧美日韩老妇| 狠狠干一区二区| 色诱色偷偷久久综合| 91sa在线看| 欧美日韩在线资源| 日韩精品免费在线视频观看| 99在线精品视频免费观看软件 | 久久免费精品国产久精品久久久久| 91香蕉视频导航| 亚洲国产专区| 在线观看一区二区三区三州| 日韩av字幕| 1区1区3区4区产品乱码芒果精品| 欧美成人免费电影| 韩剧1988在线观看免费完整版 | 久久久久中文字幕| 成人动漫在线免费观看| 亚洲第一av网站| 一级欧美一级日韩| 欧美午夜无遮挡| 国产精品二区一区二区aⅴ| 国产精品久久久久久久久搜平片| 中文字幕人妻一区二区三区| 狠狠色丁香九九婷婷综合五月 | 国内成人自拍视频| 男女午夜激情视频| 亚洲午夜在线| www.亚洲一区二区| 91亚洲国产| 色涩成人影视在线播放| 日韩高清影视在线观看| www.成人av.com| 免费看日产一区二区三区| 国产精品久久久久久久久久免费| 182在线播放| 欧美精品在线播放| 精品欧美色视频网站在线观看| 亚洲午夜女主播在线直播| 十九岁完整版在线观看好看云免费| 欧美一级免费观看| 国产乱码精品一区二三区蜜臂| 在线观看一区日韩| 日日夜夜狠狠操| 日韩欧美国产免费播放| 日韩免费视频网站| 亚洲第一搞黄网站| 国产亚洲精品女人久久久久久| 亚洲精品国产一区二区精华液| 国产色无码精品视频国产| 中文字幕在线一区| 91久久国产综合| 亚洲免费在线看| 国产一区二区视频在线观看免费| 亚洲欧洲日韩av| 精品无码久久久久成人漫画| 亚洲精品自拍动漫在线| 久久黄色免费网站| 亚洲电影第三页| 五月婷婷色丁香| 色综合中文字幕| 成人小视频在线播放| 欧美三级乱人伦电影| 91亚洲精品国偷拍自产在线观看 | 亚洲成人免费| 日韩国产小视频| 伊人久久大香线蕉av超碰演员| 日本福利视频一区| 亚洲女同同性videoxma| 亚洲不卡视频在线| 激情综合色播激情啊| 国产高清av片| 成人黄色777网| 亚洲区免费视频| 国产精品视频线看| 中文字幕手机在线观看| 亚洲国产一区二区三区 | 国产蜜臀av在线播放| 午夜精品福利视频| a日韩av网址| 国产欧美日韩高清| 亚洲一区电影| 欧美一区二区三区在线播放| 国产精品久久久乱弄| 久草免费福利在线| 日日摸夜夜添夜夜添亚洲女人| 国产精品视频中文字幕| 粉嫩嫩av羞羞动漫久久久| 黑人巨大精品欧美| 成人免费在线播放视频| 日韩av男人天堂| 欧美日韩性生活| 色呦呦免费观看| 日韩中文字幕在线免费观看| 成人女同在线观看| 国产精品高清在线观看| 日韩视频1区| 日韩在线三级| 激情偷拍久久| 日韩av卡一卡二| 成人精品gif动图一区| 亚洲一级黄色录像| 午夜精品久久久久久久久| 无码久久精品国产亚洲av影片| 日韩一级片在线播放| 九色视频在线观看免费播放| 久久99青青精品免费观看| 欧美国产大片| 国产精品二区在线观看| 欧美日韩亚洲在线观看| 成年人午夜视频在线观看| 国产原创一区二区| 亚洲精品乱码久久久久久久久久久久| 亚洲欧美日韩人成在线播放| 中文字幕一区二区三区四区欧美| 日韩免费视频线观看| 国产私拍精品| 欧美一级免费看| 亚洲无线观看| 老汉色影院首页| 蜜臀av一级做a爰片久久| 噜噜噜在线视频| 亚洲资源中文字幕| 国产又粗又大又黄| 中文字幕亚洲一区二区三区五十路 | 国产精品久久综合| 中文字幕69页| 亚洲精品电影在线观看| 黄色大片在线| 91一区二区三区| 亚洲蜜桃视频| 91高清国产视频| 中文一区二区在线观看| 天干夜夜爽爽日日日日| 日韩精品在线观看视频| xxx.xxx欧美| 国产精品久久久久久久天堂第1集| 国产精品99久久| 亚洲36d大奶网| 国产精品美女久久久久久久久久久 | 精品国产一区二区三区免费| 国精品一区二区| 日韩高清一二三区| 樱花影视一区二区| 国产视频在线免费观看| 久热爱精品视频线路一| 二区三区精品| 黄色一级大片免费| 国产**成人网毛片九色 | 一级黄色片日本| 欧美日韩精品二区第二页| 国模吧精品人体gogo| 日韩美女在线观看一区| 久久不见久久见国语| 国产视频在线视频| 日本一区二区三区四区在线视频 | 深夜福利视频一区二区| 精品网站在线看| 国产精品亚洲产品| 巨胸大乳www视频免费观看| 色94色欧美sute亚洲13| 国产黄在线播放| 国产在线观看精品一区二区三区| 91欧美大片| 成人在线短视频| 亚洲综合区在线| 香蕉久久国产av一区二区| 91大神福利视频在线| 精品视频97| 日本一本在线视频| 亚洲国产aⅴ天堂久久| 日韩三级电影网| 国产精品黄色影片导航在线观看| 热久久天天拍国产| 国产999免费视频| 亚洲成av人影院在线观看网| 深夜福利在线看| 国产精品无av码在线观看| 伊人成综合网| 少妇精品一区二区| 精品视频在线免费观看| 91麻豆免费在线视频| 久久久婷婷一区二区三区不卡| 视频精品一区二区| 加勒比婷婷色综合久久| 亚洲国产欧美一区| 久久福利在线| 国产91沈先生在线播放| 久久婷婷成人综合色| 成人毛片一区二区三区| 久久夜精品va视频免费观看| 国内精品偷拍| 日韩av卡一卡二| 无码av免费一区二区三区试看| 成人精品福利| 国产欧美韩日| 久草这里只有精品视频| 91久久国产视频| 久久国内精品一国内精品| 另类在线视频| 五月六月丁香婷婷| 日韩欧美亚洲综合| 在线观看午夜av| 欧美一区2区三区4区公司二百 | 成人资源视频网站免费| 久久亚洲欧洲| 懂色av.com| 久久五月天色综合| av亚洲免费| 国产激情在线免费观看| 日韩欧美国产不卡|