PDO::__construct() エラーについて: サーバーが不明な文字セットを送信しました
試行中に PDO::__construct() エラーが発生しましたSymfony 3 から MySQL データベースへの接続は、サーバーが文字セット (255) を送信するときに発生します。クライアントが認識しません。この問題は、デフォルトの文字セットとして utf8mb4 を採用する MySQL 8.0.1 の更新が原因で発生します。
MySQL と PHP が Docker コンテナ内で動作しているにもかかわらず、クライアントは新しい文字セットを認識しません。その結果、サーバーの応答が不明な値として解釈され、このエラーが発生します。
解決策: クライアントのアップグレード
根本的な解決策には、クライアントのアップグレードが含まれます。 utf8mb4 のサポートを組み込むことにより、クライアントはサーバーと効果的に通信し、問題を解決できます。このアップグレードにより、変更された文字セットとの互換性が確保されます。
一時的な回避策: サーバーの文字セットを変更する
または、アップグレードされていないクライアントとの互換性を維持するための一時的な回避策が存在します。 。サーバーの文字セットを utf8 に変更することで、古いクライアントの制限に合わせます。この調整は、/etc/my.cnf ファイルを変更し、次の設定で mysqld を再起動することで実装できます。
[client] default-character-set=utf8 [mysql] default-character-set=utf8 [mysqld] collation-server = utf8_unicode_ci character-set-server = utf8
この回避策で当面の問題は解決されますが、クライアントのアップグレードが長期的に推奨されます。最適な互換性とパフォーマンスを確保するためのソリューション。
以上がSymfony 3 で PDO::__construct() が「Server Sent Unknown Charset」で失敗するのはなぜですか? どうすれば修正できますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。