>  기사  >  데이터 베이스  >  MySQL에서 이모티콘이 사라지는 이유는 무엇입니까?

MySQL에서 이모티콘이 사라지는 이유는 무엇입니까?

DDD
DDD원래의
2024-11-06 20:25:02387검색

Why are my Emojis Disappearing in MySQL?

MySQL 문자 인코딩 및 이모티콘 저장

이모티콘을 PHP 백엔드로 전송한 다음 이를 MySQL에 삽입하는 iPhone 애플리케이션이 있습니다. 데이터 베이스. 하지만 삽입에 성공하면 저장된 값이 공백으로 나타납니다.

텍스트만 삽입하면 성공하지만 이모티콘이 포함되면 텍스트만 삽입됩니다. 필드 유형을 블로그(이미지 데이터 수용을 위해)로 변경하라는 제안은 가끔 이모티콘이 아닌 삽입과 작은 저장 요구 사항으로 인해 적합하지 않은 것으로 나타났습니다.

해결책: MySQL 문자 세트 호환성

문제는 MySQL의 문자 인코딩에 있습니다. iOS 이모티콘은 주로 유니코드 표의 BMP(Basic Multilingual Plane)를 초과하는 코드 포인트를 활용합니다. 예를 들어, "입을 벌리고 웃는 얼굴과 웃는 눈" 이모티콘은 U 1F604에 있습니다.

MySQL 5.5 이전 버전은 BMP용 UTF-8만 지원하므로 저장 공간은 U FFFF 이하의 문자로 제한됩니다. 결과적으로 MySQL은 U 1F604 이모티콘이나 기타 "상위 문자"를 저장할 수 없습니다.

이 문제를 해결하려면 MySQL 5.5를 사용하고 utf8mb4(인증 UTF-8), utf16 또는 utf32를 열 문자 집합으로 선택하세요. 또한 PHP와 데이터베이스 간의 MySQL 연결이 동일한 문자 세트를 사용하는지 확인하십시오.

MySQL 버전 5.5 미만의 경우 "문자"에 관계없이 원시 바이트를 저장하는 BLOB 열 유형을 사용하십시오. 이를 통해 이모티콘 저장이 가능하지만 텍스트 검색 및 색인 생성 효율성이 저하됩니다.

위 내용은 MySQL에서 이모티콘이 사라지는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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