>  기사  >  백엔드 개발  >  UTF-8 MySQL 테이블에서 Latin1 문자를 UTF-8로 변환하는 방법은 무엇입니까?

UTF-8 MySQL 테이블에서 Latin1 문자를 UTF-8로 변환하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-02 19:41:30911검색

How to Convert Latin1 Characters to UTF-8 in a UTF-8 MySQL Table?

UTF8 테이블의 Latin1 문자를 UTF8로 변환

귀하의 쿼리는 UTF8 테이블의 Latin1 문자를 UTF8로 변환하는 것과 관련이 있습니다. 문제의 세부 사항과 이 문제를 해결하는 데 도움이 되는 제공된 솔루션을 살펴보겠습니다.

배경

다음 사이에 문자 집합을 올바르게 설정해야 한다는 사실을 발견하셨습니다. UTF-8 데이터 처리를 위한 PHP 및 MySQL. 이로 인해 새로운 발음 구별 문자 삽입 문제가 해결되었습니다. 그러나 손상된 문자가 포함된 기존 행을 수정하려고 하면 문제가 발생합니다.

제안된 솔루션

제공된 솔루션은 다음 접근 방식을 활용합니다.

  1. 이진 값을 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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