UTF8 테이블의 Latin1 문자를 UTF8로 변환
귀하의 쿼리는 UTF8 테이블의 Latin1 문자를 UTF8로 변환하는 것과 관련이 있습니다. 문제의 세부 사항과 이 문제를 해결하는 데 도움이 되는 제공된 솔루션을 살펴보겠습니다.
배경
다음 사이에 문자 집합을 올바르게 설정해야 한다는 사실을 발견하셨습니다. UTF-8 데이터 처리를 위한 PHP 및 MySQL. 이로 인해 새로운 발음 구별 문자 삽입 문제가 해결되었습니다. 그러나 손상된 문자가 포함된 기존 행을 수정하려고 하면 문제가 발생합니다.
제안된 솔루션
제공된 솔루션은 다음 접근 방식을 활용합니다.
이진 값을 UTF8로 변환:
convert(cast(convert(name using latin1) as binary) using utf8)
이 MySQL 기능은 손상된 Latin1 데이터에서 UTF-8 데이터를 복구합니다.
선택적 조정(데이터 변경에 따라 다름):
초기 인코딩 변환 시 데이터가 크게 변경되지 않은 경우 내부 변환(convert(latin1을 사용한 이름))을 생략할 수 있습니다. 이 경우 함수는 다음과 같습니다.
convert(cast(name as binary) using utf8)
이 솔루션을 적용하면 UTF8 테이블에 저장된 Latin1 문자를 올바른 UTF8 형식으로 성공적으로 변환하여 문제를 해결할 수 있습니다. 캐릭터 부패 문제. 이전 인코딩 과정에서 발생한 데이터 변경의 성격에 따라 변환 기능을 조정하는 것을 잊지 마세요.
위 내용은 UTF-8 MySQL 테이블에서 Latin1 문자를 UTF-8로 변환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!