집 >데이터 베이스 >MySQL 튜토리얼 >`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 중국어 웹사이트의 기타 관련 기사를 참조하세요!