JSON エンコードで説明フィールドに NULL が返される
このシナリオでは、JSON エンコードされた出力で「説明」フィールドが NULL を返します。最初に、コードは MySQL クエリを使用してデータベース テーブルからデータを抽出し、配列に格納します。その後、配列の内容が JSON でエンコードされます。
データベース テーブルを調べると、「説明」フィールドを含むスキーマが明らかになります。ただし、出力 JSON には、このフィールドのデータは含まれません。
この問題は、文字エンコーディングに関連している可能性が高くなります:
文字エンコーディングの問題
データベースの文字セットと PHP の文字エンコーディングは異なる場合があります。 SELECT クエリの前に次のコードを使用して、明示的に UTF-8 エンコーディングを使用するようにデータベース接続とクエリを設定することをお勧めします:
mysql_query('SET CHARACTER SET utf8');
文字エンコーディングの影響
文字エンコーディングは、テキスト ファイルまたはデータベース内で文字がどのように表現されるかを定義します。エンコーディング間の不一致により、データの取得や表示が正しく行われない可能性があります。
データベース接続とクエリの両方で文字セットを UTF-8 に設定すると、取得されたデータが PHP スクリプトで予期される文字セットと確実に一致します。 JSON でエンコードする場合。これにより、「説明」フィールドの NULL の問題が解決されるはずです。
以上がJSON エンコーディングが説明フィールドに NULL を返すのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。