Rumah >pangkalan data >tutorial mysql >Bagaimanakah Saya Boleh Mengeluarkan Nilai Atribut daripada Data XML Menggunakan SQL?

Bagaimanakah Saya Boleh Mengeluarkan Nilai Atribut daripada Data XML Menggunakan SQL?

DDD
DDDasal
2024-12-20 13:44:10621semak imbas

How Can I Extract Attribute Values from XML Data Using SQL?

Mendapatkan Nilai Atribut daripada Data XML dalam SQL

Apabila bekerja dengan data XML dalam jadual pangkalan data, mungkin perlu mendapatkan semula nilai atribut khusus dalam kandungan XML. Satu cabaran yang mungkin melibatkan mengekstrak nilai atribut apabila data disimpan sebagai jenis data XML.

Format Data XML

Pertimbangkan coretan XML berikut yang disimpan dalam pangkalan data :

<email>
  <account language="en" ... />
</email>

Menyoal Atribut Nilai

Untuk mendapatkan semula nilai atribut "bahasa", anda boleh menggunakan XQuery dalam pernyataan SQL anda. XQuery ialah bahasa pertanyaan XML yang direka khusus untuk menanya dan memproses data XML.

Ekspresi XQuery

Ungkapan XQuery berikut mendapatkan semula nilai atribut "bahasa" daripada Data XML:

/email/account/@language

SQL Pertanyaan

Menggabungkan ungkapan XQuery ke dalam pertanyaan SQL anda, anda boleh mendapatkan nilai atribut seperti berikut:

declare @xml xml =
'<email>
  <account language="en" />
</email>'

select @xml.value('(/email/account/@language)[1]', 'nvarchar(max)')

Contoh Tambahan

Katakan anda mempunyai jadual bernama "@t" yang mengandungi berbilang XML baris:

insert @t values 
    ('<email><account language="en" /></email>'), 
    ('<email><account language="fr" /></email>')

Untuk mengekstrak nilai atribut daripada setiap baris, anda boleh melaksanakan pertanyaan berikut:

select m.value('(/email/account/@language)[1]', 'nvarchar(max)')
from @t

Output

The output pertanyaan di atas akan menjadi senarai nilai atribut:

en
fr

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengeluarkan Nilai Atribut daripada Data XML Menggunakan SQL?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn