午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術文章
文章詳情頁

在SQL Server中用XQuery分解XML數(shù)據(jù)

瀏覽:201日期:2023-11-01 14:32:50

本文討論SQL Server 2005的新功能,它允許你將XML數(shù)據(jù)分解到關系格式中,而不必耗用太多內存。

在舉例說明如何分解上一篇文章中的數(shù)據(jù)時,我們首先了解一下XQuery和它在SQL Server 2005中為開發(fā)者提供的功能。

XQuery介紹

XQuery,也稱作XML Query,是一種查詢XML數(shù)據(jù)的語言,允許你提取所需的節(jié)點和元素。它由W3C定義,可用于今天的大多數(shù)主流數(shù)據(jù)庫引擎中,如Oracle、DB2和SQL Server。

SQL Server 2005 XQuery函數(shù)

下面的四個函數(shù)是SQL Server 2005中的XQuery函數(shù)。(注意,XML、XQuery語句和下面的函數(shù)都區(qū)分大小寫。例如,SQL編譯器接受XML數(shù)據(jù)中的.exist,但拒絕.EXIST或.Exist。)

xml.exist

這個方法根據(jù)一個XML節(jié)點上的搜索表達式返回一個布爾值。例如,列表A中XML代碼片段中的語句將返回1(真):

SELECT @x.exist('/christmaslist/person[@gift = 'socks']')

這個語句返回0(假):

SELECT @x. exist ('/christmaslist/zach')

由于“Socks”一詞被封套,這個語句將返回0(假)。

SELECT @x.exist('/christmaslist/person[@gift = 'socks']')

xml.value

這個方法接受一個XQuery語句并返回一個單獨值。使用列表A中同樣的XML代碼片段,不可以使用VALUE函數(shù)生成“betty”值,如下所示:

SELECT @x.value('/christmaslist[1]/person[1]/@name', 'VARCHAR(20)')

而XQuery生成“zach”值。

SELECT @x.value('/christmaslist[1]/person[2]/@name', 'VARCHAR(20)')

xml.query

這個方法接受一個XQuery并返回一個XML數(shù)據(jù)類型的實例??梢园葱枰獙⑦@些查詢簡單或復雜化,下面是一個簡單的例子:

SELECT @x.query('/christmaslist/person')

它返回XML文件:

<person name='betty' gift='camera' />

<person name='zach' gift='elmo doll' />

<person name='brad' gift='socks' />

xml.nodes

在你需要將一個XML數(shù)據(jù)類型變量中的數(shù)據(jù)分解到關系數(shù)據(jù)中時,這個方法十分有用。這個方法接受一個XQuery語句作為參數(shù),并返回一個包含XML變量邏輯標量數(shù)據(jù)的行集。列表B中的查詢利用上面定義的XML變量,并將數(shù)據(jù)分解到一個結果集中,它顯示在XML變量中定義的人物姓名。

修改OPENXML存儲過程

現(xiàn)在我來說明如何修改上周的OPENXML存儲過程,使其可以應用XQuery功能。首先,我往XML變量中加載一些數(shù)據(jù)。如列表C所示。我們可以建立一個接受XML參數(shù)的過程,再應用XQuery函數(shù)把XML文件中的數(shù)據(jù)插入一個表中,而不必應用OPENXML。如列表D所示。

最初在數(shù)據(jù)庫中應用XML似乎有些難于處理,還要花一些時間習慣使用XQuery和Xpath查詢。但是,經(jīng)過一段時間的學習以后,你就會發(fā)現(xiàn)在數(shù)據(jù)庫中應用XML數(shù)據(jù)相當實用。

例如,在上述存儲過程中應用XML數(shù)據(jù),你只需調用一次數(shù)據(jù)庫,而不必像典型存儲過程編程那樣調用N次數(shù)據(jù)庫。這二者似乎區(qū)別不大,但對一個繁忙的系統(tǒng)而言,應用XML數(shù)據(jù)會有很大益處。而且,應用XQuery而非OPENXML還會顯著提高性能,對小型XML文件更是如此。

主站蜘蛛池模板: 日韩欧美亚洲综合 | 免费av在线网址 | 三级亚洲欧美 | 欧美国产一级片 | 精品国产免费一区二区三区 | 日韩天天干 | 亚洲精品一区二三区 | 欧美一区二区精品 | 国产黄色免费大片 | 色大妈| 亚洲精品一区二区在线 | 国产精品自产拍在线观看 | 久久久久一区二区三区四区 | 亚洲成人第一网站 | 在线观看免费视频一区 | 成人免费福利视频 | 日韩资源 | 老司机免费精品视频 | 亚洲一区在线视频观看 | 日韩精品乱码 | 波多野结衣一区二区 | 经典av在线 | 午夜在线一区二区 | 日本美女性爱视频 | 午夜资源站 | 午夜精品久久久久久久久久久久 | 成人av动漫在线观看 | 欧美 日韩 中文字幕 | 97超碰网 | 日韩欧美一二区 | 成人精品久久 | 青青草97国产精品麻豆 | 国产99久久久 | 黄色网页在线免费观看 | 国产成人精品一区二区三区在线观看 | 四虎免费av | 精品视频日韩 | 国产成人精品免高潮在线观看 | 4色av | 国产h视频| 天堂男人在线 |