PDO 알 수 없는 MySQL 문자 집합 딜레마
Symfony 3 애플리케이션을 통해 MySQL 데이터베이스에 연결하려고 하면 수수께끼 같은 오류가 발생할 수 있습니다. 메시지 "PDO::__construct(): 서버가 클라이언트에 알 수 없는 문자 세트(255)를 보냈습니다. 개발자." 이 문제는 서버의 기본 문자 집합과 클라이언트의 이해가 일치하지 않기 때문에 발생합니다.
배경
MySQL 버전 8.0.1에서는 기본 문자 집합을 utf8mb4로 변경했습니다. . 그러나 일부 클라이언트는 이러한 변경 사항을 인식하지 못합니다. 결과적으로 서버가 기본 문자 집합을 클라이언트에 전달할 때 인식할 수 없는 응답으로 인해 앞서 언급한 오류가 발생합니다.
해결 방법
최적의 솔루션은 클라이언트를 다음으로 업그레이드하는 것입니다. utf8mb4를 인식하는 버전입니다. 그러나 임시 조치로 업그레이드되지 않은 클라이언트를 수용하기 위해 서버의 문자 집합을 utf8로 수정할 수 있습니다. 이는 /etc/my.cnf에 다음 줄을 추가하여 수행됩니다.
[client] default-character-set=utf8 [mysql] default-character-set=utf8 [mysqld] collation-server = utf8_unicode_ci character-set-server = utf8
대체 솔루션
또 다른 잠재적 솔루션은 MySQL 연결 문자 집합을 강제로 설정하는 것입니다. 특정 값으로. PDO 연결 문자열에서 다음과 같은 charset 매개변수를 사용할 수 있습니다.
$dsn = "mysql:host=mysql;dbname=database;charset=utf8mb4;";
PDO 연결 문자열에서 charset를 명시적으로 정의하면 서버의 기본 문자 집합을 우회하고 업그레이드된 두 문자 집합과의 호환성을 보장할 수 있습니다. 업그레이드되지 않은 클라이언트.
위 내용은 My Symfony 3 응용 프로그램에서 MySQL에 연결할 때 'PDO::__construct(): Server sent charset (255)known to the client' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!