我可以在t-sql中进行查找/替换吗?

时间:2008-10-05 03:08:53

标签: sql xml tsql

我基本上有一个xml列,我需要找到并替换每个记录中的一个标记值。

3 个答案:

答案 0 :(得分:39)

对于任何真实的东西,我会选择xpaths,但有时候你需要一个快速而肮脏的解决方案:

您可以使用CAST将该xml列转换为常规varchar,然后进行正常替换。

UPDATE xmlTable SET xmlCol = REPLACE( CAST( xmlCol as varchar(max) ), '[search]', '[replace]')

当您需要运行快速查询来查找内容并且不想处理xpath时,同样的技术也会使搜索XML变得简单。

SELECT * FROM xmlTable WHERE CAST( xmlCol as varchar(max) ) LIKE '%found it!%'

编辑:只是想稍微更新一下,如果你得到一条消息将一个或多个字符从XML转换为目标整理不可能,那么你只需要使用nvarchar支持unicode。

CAST( xmlCol as nvarchar(max) )

答案 1 :(得分:16)

要查找XML列中的内容,请查看exists()方法,如MSDN here中所述。

SELECT * FROM Table
WHERE XMLColumn.exist('/Root/MyElement') = 1

...要替换,请使用modify()方法,如here所述。

SET XMLColumn.modify('
  replace value of (/Root/MyElement/text())[1]
  with "new value"
')

..所有假设SqlServer 2005或2008.这是基于XPath,你需要知道。

答案 2 :(得分:-5)

update my_table
set xml_column = replace(xml_column, "old  value", "new value")