ホームページ >データベース >mysql チュートリアル >データベース間の相互運用性シナリオで文字列フィールドに文字ではなく「?」が表示されるのはなぜですか?
データベースの文字エンコーディングが JDBC と一致しない
データベース間の相互運用性を使用する場合、文字エンコーディングの互換性が重要な役割を果たします。この特定のシナリオでは、GlassFish 3、JPA、および MySQL を使用する Java Web アプリケーションが文字エンコーディングの問題に直面します。具体的には、JPA の update() メソッドを使用して保存された String フィールドでデータ破損が発生し、「?」が表示されます。
サーバー、ページ、データベースは UTF-8 を使用するように構成されていますが、原因は別の場所にあります。 データベースへの接続時に使用される文字エンコーディングは、JPA ではなく JDBC (Java Database Connectivity) によって決まります。 したがって、JDBC 接続文字列に正しい文字エンコーディングが含まれていることを確認することが重要です。
提供されたソリューションで提案されている MySQL 接続文字列の適切な構文は次のとおりです。
jdbc:mysql://localhost:3306/administer?characterEncoding=utf8
文字エンコーディングを明示的に指定することによってJDBC では、接続にはデータベース、サーバー、およびページのエンコーディングに一致する UTF-8 が使用されます。これにより、一貫した文字表現が保証され、データの破損や特定の文字が「?」に置き換えられるのを防ぎます。
以上がデータベース間の相互運用性シナリオで文字列フィールドに文字ではなく「?」が表示されるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。