在舉例說明如何分解上一篇文章中的數據時,我們首先了解一下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文件更是如此。
新聞熱點
疑難解答