国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > SQL Server > 正文

在SQL Server 2005中用XQuery分解XML數據

2024-08-31 00:50:05
字體:
來源:轉載
供稿:網友

  本文討論sql server 2005的新功能,它允許你將xml數據分解到關系格式中,而不必耗用太多內存。我們首先了解一下xquery和它在sql server 2005中為開發者提供的功能。

  xquery介紹

  xquery,也稱作xml query,是一種查詢xml數據的語言,允許你提取所需的節點和元素。它由w3c定義,可用于今天的大多數主流數據庫引擎中,如oracle、db2和sql server。

  sql server 2005 xquery函數

  下面的四個函數是sql server 2005中的xquery函數。(注意,xml、xquery語句和下面的函數都區分大小寫。例如,sql編譯器接受xml數據中的.exist,但拒絕.exist或.exist。)xml.exist

  這個方法根據一個xml節點上的搜索表達式返回一個布爾值。例如,列表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函數生成“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數據類型的實例??梢园葱枰獙⑦@些查詢簡單或復雜化,下面是一個簡單的例子: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數據類型變量中的數據分解到關系數據中時,這個方法十分有用。這個方法接受一個xquery語句作為參數,并返回一個包含xml變量邏輯標量數據的行集。列表b中的查詢利用上面定義的xml變量,并將數據分解到一個結果集中,它顯示在xml變量中定義的人物姓名。

  修改openxml存儲過程

  現在我來說明如何修改上周的openxml存儲過程,使其可以應用xquery功能。首先,我往xml變量中加載一些數據。如列表c所示。我們可以建立一個接受xml參數的過程,再應用xquery函數把xml文件中的數據插入一個表中,而不必應用openxml。如列表d所示。

  最初在數據庫中應用xml似乎有些難于處理,還要花一些時間習慣使用xquery和xpath查詢。但是,經過一段時間的學習以后,你就會發現在數據庫中應用xml數據相當實用。

  例如,在上述存儲過程中應用xml數據,你只需調用一次數據庫,而不必像典型存儲過程編程那樣調用n次數據庫。這二者似乎區別不大,但對一個繁忙的系統而言,應用xml數據會有很大益處。而且,應用xquery而非openxml還會顯著提高性能,對小型xml文件更是如此。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 什邡市| 西和县| 集贤县| 梁山县| 射洪县| 阳原县| 乌审旗| 皋兰县| 依兰县| 宜昌市| 浦北县| 衡阳县| 泸水县| 布拖县| 五寨县| 乐昌市| 绵阳市| 阿荣旗| 都匀市| 梁河县| 江山市| 玉门市| 镇康县| 汝南县| 望都县| 南漳县| 当阳市| 阳谷县| 花莲县| 五大连池市| 内丘县| 邹城市| 石门县| 余江县| 田林县| 土默特右旗| 清徐县| 龙州县| 永州市| 桃源县| 长沙市|