>백엔드 개발 >PHP 튜토리얼 >이전 스크립트에서 MySQL로 데이터를 마이그레이션할 때 페르시아어 문자가 왜곡되는 이유는 무엇입니까?

이전 스크립트에서 MySQL로 데이터를 마이그레이션할 때 페르시아어 문자가 왜곡되는 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-09 11:04:16527검색

Why Are My Persian Characters Garbled When Migrating Data from an Old Script to MySQL?

MySQL의 잘못 인코딩된 데이터 미스터리: 이전 스크립트와 새 스크립트의 사례

데이터 저장 및 검색 영역에서는 작업 시 예상치 못한 동작이 발생하는 경우가 많습니다. 다른 시스템으로. 이전 스크립트에서 새 스크립트로 데이터를 마이그레이션하려고 시도하는 개발자가 겪는 수수께끼 같은 인코딩 불일치가 바로 그러한 경우입니다.

문제: 잘못된 문자

개발자 특이한 문제에 직면했습니다. 이전 스크립트에서 UTF-8을 사용하여 인코딩된 페르시아어 문자는 두 스크립트가 모두 동일한 것을 사용했음에도 불구하고 새 스크립트를 사용할 때 왜곡된 텍스트로 나타납니다. 문자 집합(UTF-8).

The Suspect: Database Configuration

초기 문제 해결 노력은 데이터베이스 설정에 중점을 두었습니다. 이전 스크립트는 사용자 정의 데이터베이스 엔진을 사용했지만 새 스크립트는 MySQL을 사용했습니다. 호환성을 보장하기 위해 개발자는 MySQL 데이터베이스의 문자 집합과 데이터 정렬이 각각 UTF-8 및 UTF-8_persian_ci로 설정되어 있는지 확인했습니다.

이상한 동작

올바른 문자 집합과 데이터 정렬을 설정했음에도 불구하고 불일치가 지속되었습니다. 이전 스크립트는 계속해서 페르시아어 문자를 올바르게 표시했지만 새 스크립트는 여전히 잘못된 텍스트를 표시했습니다.

근본 원인: 연결 사고

문제를 더 자세히 살펴본 후 , 개발자는 미묘하지만 중요한 세부 사항을 발견했습니다. 즉, 이전 스크립트에서 사용된 데이터베이스 연결이 Latin1로 설정되었습니다. 명백히 무해해 보이는 이 설정은 데이터 인코딩에 중요한 영향을 미쳤습니다.

어떻게 발생했는지

데이터가 이전 스크립트를 사용하여 데이터베이스에 처음 삽입되었을 때 PHP는 UTF-8로 인코딩된 문자열을 데이터베이스에 추가합니다. 연결이 Latin1로 설정되었으므로 데이터베이스는 페르시아어 문자를 나타내는 바이트를 Latin1 값으로 해석했습니다. 결과적으로 문자가 잘못된 인코딩으로 데이터베이스에 저장되었습니다.

해결책: 데이터베이스 변환

조각 오류를 해결하기 위해 개발자는 데이터를 변환해야 했습니다. 데이터베이스에서 올바른 UTF-8 형식으로 변경하세요. 이는 다음 SQL 문을 사용하여 달성할 수 있습니다.

SELECT CONVERT(BINARY CONVERT(field_name USING latin1) USING utf8) FROM table_name

변환이 완료되면 페르시아어 문자가 올바른 UTF-8 인코딩으로 데이터베이스에 저장되었습니다. 이제 새 스크립트는 이전 스크립트의 출력과 일치하도록 데이터를 올바르게 검색하고 표시할 수 있습니다.

위 내용은 이전 스크립트에서 MySQL로 데이터를 마이그레이션할 때 페르시아어 문자가 왜곡되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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