Catatan
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba masuk atau mengubah direktori.
Akses ke halaman ini memerlukan otorisasi. Anda dapat mencoba mengubah direktori.
Kueri SELECT mengembalikan hasil sebagai set baris. Anda dapat secara opsional mengambil hasil formal kueri SQL sebagai XML dengan menentukan klausa FOR XML dalam kueri. Klausa FOR XML dapat digunakan dalam kueri tingkat atas dan dalam sub kueri. Klausa FOR XML tingkat atas hanya dapat digunakan dalam pernyataan SELECT. Dalam sub kueri, FOR XML dapat digunakan dalam pernyataan INSERT, UPDATE, dan DELETE. Ini juga dapat digunakan dalam pernyataan penugasan.
Dalam klausa FOR XML, Anda menentukan salah satu mode ini:
MENTAH
Mobil
EKSPLISIT
JALAN
Mode RAW menghasilkan elemen <row> tunggal per baris dalam set baris yang dikembalikan oleh pernyataan SELECT. Anda dapat membuat hierarki XML dengan menulis kueri XML berlapis.
Mode AUTO menghasilkan struktur bersarang dalam XML yang dihasilkan dengan menerapkan heuristik berdasarkan spesifikasi pernyataan SELECT. Anda memiliki kontrol minimal atas bentuk XML yang dihasilkan. Kueri XML berlapis dapat ditulis untuk menghasilkan hierarki XML di luar bentuk XML yang dihasilkan oleh heuristik mode OTOMATIS.
Mode EKSPLISIT memungkinkan lebih banyak kontrol atas bentuk XML. Anda dapat mencampur atribut dan elemen sesuai kemauan dalam memutuskan bentuk XML. Ini memerlukan format tertentu untuk kumpulan baris yang dihasilkan yang dihasilkan karena eksekusi kueri. Format set baris ini kemudian dipetakan ke dalam bentuk XML. Kekuatan mode EKSPLISIT adalah mencampur atribut dan elemen sesering mungkin, membuat pembungkus dan properti kompleks berlapis, membuat nilai yang dipisahkan ruang (misalnya, atribut OrderID mungkin memiliki daftar nilai ID pesanan), dan konten campuran.
Namun, menulis kueri mode EKSPLISIT bisa memakan waktu. Anda dapat menggunakan beberapa kemampuan FOR XML baru, seperti menulis kueri mode FOR XML RAW/AUTO/PATH berlapis dan direktif TYPE, alih-alih menggunakan mode EKSPLISIT untuk menghasilkan hierarki. Kueri XML berlapis dapat menghasilkan XML apa pun yang dapat Anda hasilkan dengan menggunakan mode EKSPLISIT. Untuk informasi selengkapnya, lihat Gunakan Kueri FOR XML Berlapis dan Direktif TYPE dalam Kueri XML.
Mode PATH bersama dengan kemampuan kueri XML BERlapis memberikan fleksibilitas mode EKSPLISIT dengan cara yang lebih sederhana.
Mode ini hanya berlaku untuk eksekusi kueri yang ditetapkan. Mereka tidak memengaruhi hasil kueri berikutnya.
FOR XML tidak valid untuk pilihan apa pun yang digunakan dengan klausa FOR BROWSE.
Contoh
Pernyataan berikut SELECT mengambil informasi dari tabel Sales.Customer dan Sales.SalesOrderHeader dalam basis data AdventureWorks2012. Kueri ini menentukan mode AUTO dalam klausa FOR XML.
USE AdventureWorks2012
GO
SELECT Cust.CustomerID,
OrderHeader.CustomerID,
OrderHeader.SalesOrderID,
OrderHeader.Status
FROM Sales.Customer Cust
INNER JOIN Sales.SalesOrderHeader OrderHeader
ON Cust.CustomerID = OrderHeader.CustomerID
FOR XML AUTO
Klausul FOR XML dan Nama Server
Saat pernyataan SELECT dengan klausul FOR XML menentukan nama empat bagian dalam kueri, nama server tidak dikembalikan dalam dokumen XML yang dihasilkan saat kueri dijalankan di komputer lokal. Namun, nama server dikembalikan sebagai nama empat bagian saat kueri dijalankan di server jaringan.
Misalnya, pertimbangkan kueri ini:
SELECT TOP 1 LastName
FROM ServerName.AdventureWorks2012.Person.Person
FOR XML AUTO
Saat ServerName adalah server lokal, kueri mengembalikan yang berikut ini:
<AdventureWorks2012.Person.Person LastName="Achong" />
Saat ServerName adalah server jaringan, kueri mengembalikan yang berikut ini:
<ServerName.AdventureWorks2012.Person.Person LastName="Achong" />
Ambiguitas potensial ini dapat dihindari dengan menentukan alias ini:
SELECT TOP 1 LastName
FROM ServerName.AdventureWorks2012.Person.Person x
FOR XML AUTO
Kueri ini mengembalikan yang berikut ini:
<x LastName="Achong"/>
Lihat Juga
Sintaks Dasar Klausul FOR XML
Gunakan Mode RAW dengan FOR XML
Menggunakan Mode OTOMATIS dengan FOR XML
Gunakan Mode EKSPLISIT dengan FOR XML
Gunakan Mode JALUR dengan FOR XML
OPENXML (SQL Server)
Menambahkan Namespace ke Kueri dengan XMLNAMESPACES