>데이터 베이스 >MySQL 튜토리얼 >`REPLACE()` 함수를 사용하여 MySQL 레코드의 여러 문자열을 올바르게 바꾸는 방법은 무엇입니까?

`REPLACE()` 함수를 사용하여 MySQL 레코드의 여러 문자열을 올바르게 바꾸는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-05 13:21:10704검색

How to Correctly Replace Multiple Strings in MySQL Records Using the `REPLACE()` Function?

replace()를 사용하여 여러 MySQL 레코드에서 문자열 바꾸기

문제:

데이터베이스에 손상된 데이터가 있는 레코드가 포함되어 있습니다. 특정 열. 특히 특정 문자가 잘못 이스케이프되어 생성된 링크의 기능이 중단되었습니다. 목표는 MySQL 바꾸기() 함수를 사용하여 영향을 받은 모든 레코드에서 이러한 잘못된 문자를 바꾸는 것입니다.

해결책:

MySQL에서 바꾸기() 함수를 사용하려면 , 다음 구문을 따르세요.

UPDATE MyTable
SET StringColumn = REPLACE(StringColumn, 'SearchForThis', 'ReplaceWithThis')
WHERE SomeOtherColumn LIKE '%PATTERN%';

제공된 시나리오에서는 "<" 문자열을 바꿔야 합니다. 리터럴 꺾쇠 괄호 "<" 사용 "<"가 포함된 모든 레코드의 itemItem 열에 있습니다. 이러한 문자가 "GREATERTHAN"으로 이스케이프되었을 가능성을 고려하면 쿼리는 다음과 같습니다.

UPDATE MyTable
SET articleItem = REPLACE(articleItem, 'GREATERTHAN', '>');</p>
<p>교체해야 하는 문자가 여러 개 있는 경우 교체() 함수를 중첩할 수 있습니다.</p> <pre class="brush:php;toolbar:false">UPDATE MyTable
SET articleItem = REPLACE(REPLACE(articleItem, 'GREATERTHAN', '>'), 'LESSTHAN', '<');

단일 쿼리 접근 방식:

위 쿼리는 다음을 수행할 수 있습니다. 단일 쿼리에서 여러 문자를 바꾸는 데 사용됩니다. 데이터를 선택하는 동안 교체를 수행할 수도 있습니다.

SELECT REPLACE(MyURLString, 'GREATERTHAN', '>') AS MyURLString
FROM MyTable;

이 예에서는 원래 열을 업데이트하는 대신 교체된 문자열이 MyURLString으로 반환됩니다.

위 내용은 `REPLACE()` 함수를 사용하여 MySQL 레코드의 여러 문자열을 올바르게 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.