当前位置:  开发笔记 > 数据库 > 正文

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

如何解决《我可以在t-sql中进行查找/替换吗?》经验,为你挑选了2个好方法。

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



1> Cory Mawhort..:

对于任何真实的东西,我会选择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) )



2> Michael Petr..:

要查找XML列的内容,寻找到存在()方法,如在MSDN描述这里.

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

...更换,使用修改()方法,如描述在这里.

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

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

推荐阅读
有风吹过best
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有