Как удалить атрибут из переменной 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