且构网

分享程序员开发的那些事...
且构网 - 分享程序员编程开发的那些事

如何使用mySQL replace()替换多个记录中的字符串?

更新时间:2023-02-18 09:23:28

非常普通的水平

UPDATE MyTable

SET StringColumn = REPLACE (StringColumn, 'SearchForThis', 'ReplaceWithThis')

WHERE SomeOtherColumn LIKE '%PATTERN%'

在您的情况下,您说这些已被转义,但是由于您未指定如何转义,因此假设它们已转义到GREATERTHAN

In your case you say these were escaped but since you don't specify how they were escaped, let's say they were escaped to GREATERTHAN

UPDATE MyTable

SET StringColumn = REPLACE (StringColumn, 'GREATERTHAN', '>')

WHERE articleItem LIKE '%GREATERTHAN%'

由于您的查询实际上将在字符串中运行,因此您的WHERE子句进行模式匹配不太可能提高任何性能-实际上,它将为服务器产生更多的工作.除非您有另一个WHERE子句成员将使此查询的性能更好,否则您可以像这样简单地进行更新:

Since your query is actually going to be working inside the string, your WHERE clause doing its pattern matching is unlikely to improve any performance - it is actually going to generate more work for the server. Unless you have another WHERE clause member that is going to make this query perform better, you can simply do an update like this:

UPDATE MyTable
SET StringColumn = REPLACE (StringColumn, 'GREATERTHAN', '>')

您还可以嵌套多个REPLACE调用

UPDATE MyTable
SET StringColumn = REPLACE (REPLACE (StringColumn, 'GREATERTHAN', '>'), 'LESSTHAN', '<')

您也可以在选择数据时(而不是保存时)执行此操作.

You can also do this when you select the data (as opposed to when you save it).

所以不是:

SELECT MyURLString From MyTable

你可以做

SELECT REPLACE (MyURLString, 'GREATERTHAN', '>') as MyURLString From MyTable