原因: java.sql.SQLException: 列の文字列値が正しくありません: '\xF0\x9F\x94\xA5'。Mysql に絵文字式を保存するときにエラーが発生します。 iOS の絵文字 (emoji 顔文字) は、UTF8 でエンコードされていますが、1 文字が 4 バイトを占めますが、MySQL の UTF8 エンコードでは 3 バイトの文字しか保存できません。 MySQL 5.6 では、エンコーディングを utf8 のスーパーセットである utf8mb4 に設定できます。 1. MYSQLの文字セットを変更する Mysql は文字エンコード セットを utf8mb4 に設定し、対応するデータベース、テーブル、フィールドも utf8mb4 に設定されます。既存のテーブルの utf8 エンコード セットを utf8mb4 に変更する場合は、データベース、テーブル、フィールドを一度設定して確認する必要があることに注意してください。データベースのみを変更した場合、対応するテーブルとフィールドは変更されません。テーブルを変更した場合も同様です。設定を変更した場合は、データベースを再起動する必要がある場合もあります。 文字セットサーバー=utf8mb4 2. JDBCをアップグレードする 下位バージョンの JDBC では、文字化けした文字、表現、さらには中国語の文字も表示されます。 以下は、JDBC バージョンの対応する状況の一部です。詳細は次のとおりです。JDBC バージョンは EMOJI をサポートしています。画像はインターネットで見つかりました。私の 5.1.6 テストでは、中国語と絵文字表現が正常に挿入され、表示されます。 3. サーバー構成 jdbc:mysql://xxx.xxx.xxx.xxx:3306/dbwww58com_chrcsm?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true を継承します。接続アドレスの後のパラメータは UTF-8 に設定されているか、自動的に認識されます。そうでない場合は、太字部分を削除して、接続がサーバー構成を自動的に認識できるようにします。具体的な状況は JDBC のバージョンによって異なります。サーバー構成 jdbc:mysql://xxx.xxx.xxx.xxx:3306/dbwww58com_chrcsm?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true を継承します。接続アドレスの後のパラメータは UTF-8 に設定されているか、自動的に認識されます。そうでない場合は、太字部分を削除して、接続がサーバー構成を自動的に認識できるようにします。具体的な状況は JDBC のバージョンによって異なります。 4. MYSQLのinit_connectパラメータを設定する 設定後、図 2 init_connect パラメータ クエリに示すように、「init_connect」などの変数を表示して確認できます。 5. エンコーディング セットはコードで設定されています。おそらく、JDBC のバージョンによるものだと思います。この方法を使用すると、挿入とクエリの両方が正常に実行できます。 connection.prepareStatement("set names utf8mb4").executeQuery();次に、connection.prepareStatement を通じて挿入します。おそらくJDBCのバージョンのせいか、コード内にエンコーディングセットが設定されています。この方法を使用すると、挿入とクエリの両方が正常に実行できます。 connection.prepareStatement("set names utf8mb4").executeQuery();次に、connection.prepareStatement を通じて挿入します。 以下もご興味があるかもしれません:
|
<<: 開発効率を向上させる 20 の JavaScript ヒント
>>: Linux (CentOS7) に Tomcat をインストールし、Tomcat をスタートアップ項目として設定します (tomcat8 を例に挙げます)
この記事では、MySQL 8.0.12のインストールチュートリアルを参考までに紹介します。具体的な内...
目次サーバー計画1. システムコンポーネントをインストールする2. fastdfsをインストールする...
私は2年間運用保守に携わり、多くのコマンドを使用しました。特定のLinuxコマンドを習得すると、どれ...
dokekrでmysqlコンテナを起動するコマンドを使用します: docker run -p 330...
will-change は、要素にどのような変更が行われるかをブラウザに伝え、ブラウザが事前に最適化...
いくつかのテーブルまたは単一のデータベースのみをバックアップする場合は、innobackup よりも...
目次ルートの場所が見つかりませんオフバイスラッシュ安全でない変数の使用スクリプト名$uri を使用す...
目次シンプルなSpringbootプロジェクトを作成する1. pom.xmlでSpring Boot...
序文データベースでは、一部のデータ テーブルとデータは latin1 であり、一部のデータ テーブル...
1 MySQL5.6 1.1 関連パラメータMySQL 5.6 では、innodb_undo_dir...
この記事では、MySQL 8.0.13のインストールと設定のチュートリアルを参考までに紹介します。具...
LOFTER のコンテストで、ログイン ボックスを再設計できると言及されているのを見ました。過去 2...
一般的に言えば、HTML ドキュメント内で極端に大きな <ol> リストに遭遇する可能性...
多くの場合、大規模および中規模の Web サイトでは、静的リソース (フォント ファイル、画像など)...
目次導入子プロセスプロセスを非同期的に作成する同期作成プロセス導入Node.js のメイン イベント...