Menghapuskan Pengisytiharan Ruang Nama Terlebih dalam Nested FOR XML PATH Queries
Dalam pertanyaan FOR XML PATH dengan ruang nama lalai diisytiharkan menggunakan WITH XMLNAMESPACES, adalah perkara biasa untuk menemui pengisytiharan ruang nama pendua dalam pertanyaan bersarang. Artikel ini menangani isu ini dan menyediakan penyelesaian yang optimum.
Masalah timbul apabila subkueri menggunakan FOR XML dan mewarisi ruang nama lalai daripada pertanyaan luar. Ini menghasilkan pengisytiharan ruang nama berbilang untuk nod subkueri. Walaupun terdapat pelbagai penyelesaian dalam talian, tiada satu pun menyelesaikan masalah ini sepenuhnya.
Penyelesaian Optimum
Selepas percubaan yang meluas, penyelesaian berikut telah dianggap paling berkesan:
DECLARE @Order TABLE (OrderID INT, OrderDate DATETIME) DECLARE @OrderDetail TABLE (OrderID INT, ItemID VARCHAR(1), Name VARCHAR(50), Qty INT) INSERT @Order VALUES (1, '2010-01-01'), (2, '2010-01-02') INSERT @OrderDetail VALUES (1, 'A', 'Drink', 5), (1, 'B', 'Cup', 2), (2, 'A', 'Drink', 2), (2, 'C', 'Straw', 1), (2, 'D', 'Napkin', 1) -- FOR XML PATH query DECLARE @xml XML = (SELECT OrderID AS "@OrderID", (SELECT ItemID AS "@ItemID", Name AS "data()" FROM @OrderDetail WHERE OrderID = o.OrderID FOR XML PATH ('Item'), TYPE) FROM @Order o FOR XML PATH ('Order'), ROOT('dummyTag'), TYPE) -- Magic happens here! SELECT 1 AS Tag ,NULL AS Parent ,@xml AS [xml!1!!xmltext] ,'http://test.com/order' AS [xml!1!xmlns] FOR XML EXPLICIT
Penyelesaian ini menggunakan pertanyaan FOR XML EXPLICIT untuk membalut hasil pertanyaan FOR XML PATH, dengan berkesan mengalih keluar pengisytiharan ruang nama yang tidak diingini.
Hasil
Output daripada pertanyaan ini ialah:
<xml xmlns="http://test.com/order"> <Order OrderID="1"> <Item ItemID="A">Drink</Item> <Item ItemID="B">Cup</Item> </Order> <Order OrderID="2"> <Item ItemID="A">Drink</Item> <Item ItemID="C">Straw</Item> <Item ItemID="D">Napkin</Item> </Order> </xml>
Pengisytiharan ruang nama kini hanya terdapat pada nod akar, seperti yang dimaksudkan.
Atas ialah kandungan terperinci Bagaimana untuk Menghapuskan Pengisytiharan Ruang Nama Berlebihan dalam Pertanyaan Nested FOR XML PATH?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!