select
Roles
from
MyTable
where
Roles.value('(/root/role)[1]', 'varchar(max)') like 'StringToSearchFor'
หน้าเหล่านี้จะแสดงข้อมูลเพิ่มเติมเกี่ยวกับวิธีการสืบค้น XML ใน T-SQL:
การสืบค้นฟิลด์ XML โดยใช้ t-sql
การแบนข้อมูล XML ใน SQL Server
แก้ไข
หลังจากที่เล่นกับมันนิด ๆ หน่อย ๆ ผมจบลงด้วยแบบสอบถามที่น่าตื่นตาตื่นใจนี้ที่ใช้CROSS ใช้ อันนี้จะค้นหาทุกแถว (บทบาท) สำหรับค่าที่คุณใส่ในนิพจน์ like ของคุณ ...
ด้วยโครงสร้างตารางนี้:
create table MyTable (Roles XML)
insert into MyTable values
('<root>
<role>Alpha</role>
<role>Gamma</role>
<role>Beta</role>
</root>')
เราสามารถสอบถามได้ดังนี้:
select * from
(select
pref.value('(text())[1]', 'varchar(32)') as RoleName
from
MyTable CROSS APPLY
Roles.nodes('/root/role') AS Roles(pref)
) as Result
where RoleName like '%ga%'
คุณสามารถตรวจสอบ SQL Fiddle ได้ที่นี่: http://sqlfiddle.com/#!18/dc4d2/1/0
[1]
คำตอบของคุณทำอะไร?