Как удалить атрибут из переменной XML в sql server 2008?
у меня есть таблица под названием XML (в SQL Server 2008), и у нее есть поле под названием XmlDocument
типа XML
. Я пытаюсь удалить атрибут из XML-переменной.
вот как выглядит мой xml
<clue_personal_auto xmlns="http://cp.com/rules/client">
<admin>
<receipt_date>03/16/2011</receipt_date>
<date_request_ordered>03/16/2011</date_request_ordered>
<report_usage>Personal</report_usage>
</admin>
</clue_personal_auto>
запрос
UPDATE XML
SET XmlDocument.modify('delete (/clue_personal_auto/@xmlns)[1]')
WHERE xmlid = 357
когда я запускаю этот запрос в query analyzer, я вижу сообщение" 1 строка(ы) затронуты", но на самом деле атрибут xmlns элемента clue_personal_auto не удаляется. Любая идея, что я делаю неправильный.
спасибо BB
3 ответов
Я не могу найти простой способ сделать это - но реальный вопрос остается:Почему вы хотите удалить пространство имен?? С помощью WITH XMLNAMESPACES ...
строительство, вы можете легко использовать пространства имен.
вместо того, чтобы прикладывать много усилий, чтобы избавиться от него - узнайте о пространствах имен XML и начните их использовать!
вы можете легко использовать это пространство имен XML в своих запросах:
;WITH XMLNAMESPACES (DEFAULT 'http://cp.com/rules/client' )
SELECT
XmlDocument.value('(/clue_personal_auto/admin/report_usage)[1]', 'varchar(25)')
FROM XML
WHERE ID = 357
и быть счастливым с ним-нет необходимости искусственно удалить
вам нужно использовать С xmlnamespaces, в противном случае" /clue_personal_auto " не соответствует пространству имен clue_personal_auto xmlns="..."
узел.
мало того, вы не можете удалить пространство имен, поскольку оно не является обычным атрибутом.
пример удаления обычного атрибута
declare @xml table (xmlid int, xmldocument xml)
insert @xml select 357, '
<clue_personal_auto xmlns="http://cp.com/rules/client" otherattrib="x">
<admin>
<receipt_date>03/16/2011</receipt_date>
<date_request_ordered>03/16/2011</date_request_ordered>
<report_usage>Personal</report_usage>
</admin>
</clue_personal_auto>'
;WITH XMLNAMESPACES ('http://cp.com/rules/client' as ns)
UPDATE @XML
SET XmlDocument.modify('delete (/ns:clue_personal_auto/@otherattrib)[1]')
WHERE xmlid = 357
select * from @xml
UPDATE XML
SET CONVERT(XML, REPLACE(CONVERT(NVARCHAR(MAX), XmlDocument), N' xmlns=...'))
WHERE ID = 357