一尘不染

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

sql

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


阅读 113

收藏
2021-03-17

共1个答案

一尘不染

对于真正的东西,我会使用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转换为目标排序规则
,那么您只需要使用支持unicode的nvarchar。

CAST( xmlCol as nvarchar(max) )

2021-03-17