国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

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

SQL Server 2005 FOR XML嵌套查詢使用詳解

瀏覽:3日期:2023-11-05 19:59:36

相比SQL Server 2000提供的FOR XML查詢,SQL Server 2005版本對現有功能增強的基礎上增加了不少新功能,最為吸引人的功能包括對Xml數據類型支持、使用PATH模式以及嵌套FOR XML查詢支持等,這意味著通過新的FOR XML查詢功能可以構造出結構更加靈活的Xml數據。

在SQL Server 2000中FOR XML查詢的結果是直接以文本方式返回到客戶端,為支持SQL Server 2005中的Xml數據類型,FOR XML 查詢提供了TYPE指令,通過TYPE支持返回結果將會變為Xml數據類型。接下來以SQL Server2005中的AdventureWorks示例數據庫為例演練其功能。

先來看第一個SQL查詢:

DECLARE @TestStringValue nvarchar(1024);

SET @TestStringValue = (SELECT ProductID,[Name] FROM Production.Product

WHERE ProductSubcategoryID = 9

FOR XML AUTO);

SELECT @TestStringValue;

輸出結果:

結果為字符串,只是內容格式符合Xml片段要求,不過無法在SQL Server Management Studio中點擊以Xml方式顯示。

下面對SQL進行修改,增加TYPE指令:

DECLARE @TestStringValue nvarchar(1024);

SET @TestStringValue = (SELECT ProductID,[Name] FROM Production.Product

WHERE ProductSubcategoryID = 9

FOR XML AUTO,TYPE);

不出意外,查詢結果收到如下錯誤提示:

不允許從數據類型xml 到nvarchar 的隱式轉換。請使用CONVERT 函數來運行此查詢。

可見通過TYPE指令返回的數據已經轉變成Xml類型,改進后的查詢語句如下:

DECLARE @XmlTestValue xml;

SET @XmlTestValue = (SELECT ProductID,[Name] FROM Production.Product

WHERE ProductSubcategoryID = 9

FOR XML AUTO,TYPE);

SELECT @XmlTestValue;

通過SELECT 返回的結果支持Xml方式顯示。

了解了TYPE指令的功能后,就可以來看FOR XML查詢帶給開發者的更多驚喜。以示例數據庫的產品表(Production.Product)和產品分類子類表(Production.ProductSubcategory)為例進行演示。

編寫產品子類別為“9”的產品數據查詢:

SELECT ProductSubcategoryID,[Name] ,

(SELECT ProductID,[Name] FROM Production.Product Product

WHERE ProductSubcategoryID = 9

FOR XML AUTO,TYPE) AS Products

FROM Production.ProductSubcategory AS Category

WHERE ProductSubcategoryID = 9

FOR XML AUTO;

輸出結果如下:

如果在產品查詢子句中不提供TYPE指令,那么輸出就會變成下面結果:

' />

以上幾個查詢結果都沒有帶命名空間,不過SQL Server 2005 通過WITH XMLNAMESPACES子句提供了對命名空間的支持,下面的查詢將顯示一個完整的帶默認命名空間的Xml文檔。

WITH XMLNAMESPACES ('uri0' as ns0)

SELECT ProductSubcategoryID,[Name] ,

(SELECT ProductID,[Name] FROM Production.Product Product

WHERE ProductSubcategoryID = 9

FOR XML RAW('ns0:Product'),TYPE) AS 'ns0:Products'

FROM Production.ProductSubcategory AS Category

WHERE ProductSubcategoryID = 9

FOR XML RAW('ns0:Category'),ROOT('ns0:Message');

輸出結果:

如果采用默認命名空間,編寫SQL如下:

WITH XMLNAMESPACES (DEFAULT 'http://blog.csdn.net/zhzuo')

SELECT ProductSubcategoryID,[Name] ,

(SELECT ProductID,[Name] FROM Production.Product Product

WHERE ProductSubcategoryID = 9

FOR XML AUTO,TYPE) AS Products

FROM Production.ProductSubcategory AS Category

WHERE ProductSubcategoryID = 9

FOR XML AUTO,ROOT('Message');

輸出結果:

另外,在SQL Server 2005中增加了FOR XML PATH 模式,通過使用FOR XML PATH 模式可以建立清晰靈活的Xml格式,相比使用FOR XML EXPLICIT更為簡單:

WITH XMLNAMESPACES (DEFAULT 'http://blog.csdn.net/zhzuo')

SELECT ProductID AS 'Product/@ProductID',

Name AS 'Product/Name'

FROM Production.Product

WHERE ProductSubcategoryID = 9

FOR XML PATH(''),ROOT('Products');

輸出結果:

Rear Derailleur

Front Derailleur

在實際應用過程中,以.NET平臺應用開發為例,通過ADO.NET訪問SQL Server 2005返回的Xml數據結構可以更加豐富,甚至可以做到不做Xml樣式轉換直接服務于上一層模塊。在企業應用集成方面,以BizTalk平臺為例,在調用SQL Adapter的時候可以更加靈活,降低為了制定合理Xml Schema帶來的復雜性。目前,最新版本的BizTalk(2006 R2)對使用了SQL Server 2005加強FOR XML功能的存儲過程或SQL語句不支持通過SQL適配器向導生成XML Schema,不過這個問題可以直接通過Visual Studio IDE編寫符合實際格式的XML Schema來解決。

標簽: Sql Server 數據庫
主站蜘蛛池模板: 国内精品久久影视 | 美国三级在线观看 | 国产精品久久免费 | 一级片免 | 日韩免费一级片 | 九九免费精品视频 | 日本久久香蕉一本一道 | 香港三级日本三级人妇网站 | 成人国产永久福利看片 | 九九re6精品视频在线观看 | 欧美日韩 国产区 在线观看 | 欧美成人综合在线观看视频 | 亚洲大片免费 | 韩国福利影视一区二区三区 | 久草视频在线免费 | 一级一级毛片看看 | 高清在线观看自拍视频 | 国产美女精品一区二区三区 | 波多野结衣手机视频一区 | 一级毛片aaa片免费观看 | 怡红院视频在线观看 | 在线中文字日产幕 | 欧美一级毛片免费播放aa | 日韩午夜视频在线观看 | 在线欧美一级毛片免费观看 | 失禁h啪肉尿出来高h健身房 | 在线观看中文字幕国产 | 久久精品免视着国产成人 | 在线观看片成人免费视频 | 国产亚洲一区二区三区在线观看 | 福利姬在线精品观看 | 一级中国乱子伦视频 | 精品国产成人 | 免费的特黄特色大片在线观看 | 亚洲另类激情综合偷自拍 | 草草影院永久在线观看 | 成人免费一级在线播放 | 久久综合婷婷香五月 | 免费看美女午夜大片 | 97久久曰曰久久久 | 久久www免费人成看国产片 |