我有一个表(SQL服务器)引用路径(UNC或其他),但现在路径将会改变。
在路径列中,我有许多记录,我只需要改变路径的一部分,而不是整个路径。我需要在每条记录中,将相同的字符串更改为新的字符串。
我如何通过简单的更新来做到这一点?
我有一个表(SQL服务器)引用路径(UNC或其他),但现在路径将会改变。
在路径列中,我有许多记录,我只需要改变路径的一部分,而不是整个路径。我需要在每条记录中,将相同的字符串更改为新的字符串。
我如何通过简单的更新来做到这一点?
当前回答
select replace(ImagePath, '~/', '../') as NewImagePath from tblMyTable
其中“ImagePath”是我的列名。“NewImagePath”是临时的 列名称而不是“ImagePath”“~/”是我的当前字符串。(老 字符串)“. ./"是我需要的字符串。(新字符串) “tblMyTable”是我在数据库中的表。
其他回答
很简单:
update my_table
set path = replace(path, 'oldstring', 'newstring')
UPDATE CustomReports_Ta
SET vchFilter = REPLACE(CAST(vchFilter AS nvarchar(max)), '\\Ingl-report\Templates', 'C:\Customer_Templates')
where CAST(vchFilter AS nvarchar(max)) LIKE '%\\Ingl-report\Templates%'
没有CAST函数,我得到了一个错误
参数数据类型ntext对于replace函数的参数1无效。
您可以使用这个查询
update table_name set column_name = replace (column_name , 'oldstring' ,'newstring') where column_name like 'oldstring%'
select replace(ImagePath, '~/', '../') as NewImagePath from tblMyTable
其中“ImagePath”是我的列名。“NewImagePath”是临时的 列名称而不是“ImagePath”“~/”是我的当前字符串。(老 字符串)“. ./"是我需要的字符串。(新字符串) “tblMyTable”是我在数据库中的表。
你也可以在运行时为电子邮件模板替换大文本,这是一个简单的例子。
DECLARE @xml NVARCHAR(MAX)
SET @xml = CAST((SELECT [column] AS 'td','',
,[StartDate] AS 'td'
FROM [table]
FOR XML PATH('tr'), ELEMENTS ) AS NVARCHAR(MAX))
select REPLACE((EmailTemplate), '[@xml]', @xml) as Newtemplate
FROM [dbo].[template] where id = 1