Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Löschen Sie den XML-Knoten aus der Tabellenspalte von SQL Server 2008 r2 basierend auf dem Attributwert

Nun, da Ihr XML-Attribut id ist der XML-Namespace mit dem Präfix p5 , müssen Sie auch diesen zweiten XML-Namespace in Ihrem Code deklarieren und verwenden:

declare @lookupvalueId varchar(50)
declare @ruleId varchar(50)

set @lookupvalueId = 'b897f3ac-b40f-4b96-b438-eb156a26457e'
set @ruleId = 'fc39f423-05c0-4de9-ae46-12fe3c0c279b'

;WITH XMLNAMESPACES ('urn:gjensidige:processguide:201201' as qn,
                     'urn:gjensidige:processguide:201201' as p5)
update 
    pdr_processdefinitionrule
set 
    PDR_RuleXml.modify('delete (/qn:DifficultyRule/qn:FromControls/qn:Control/qn:FilterValues/qn:FilterValue[@p5:Id=sql:variable("@lookupvalueId")])')
where 
    pdr_guid = @ruleId

Siehe diese zweite XML-Namespace-Definition für p5 ? Sehen Sie sich die Verwendung dieses XML-Namensraums in qn:FilterValue[@p5:Id=sql:variable("@lookupvalueId")] an Ausdruck?