失敗のシナリオ MySQL データベースに絵文字表現を挿入するために JDBC を呼び出すと、例外 失敗の原因 MySQL の utf8 エンコーディングの文字は最大 3 バイトですが、絵文字表現は 4 バイトであるため、utf8 では絵文字表現の保存はサポートされていません。ただし、utf8 のスーパーセットである utf8mb4 は、文字あたり最大 4 バイトを持つことができるため、絵文字表現の保存をサポートできます。 詳しい紹介を見てみましょう。 解決 1. データベース、テーブル、列の文字セットを変更する データベースの文字セットを変更する ALTER DATABASE データベース名 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci; テーブル文字セットを変更する ALTER TABLE テーブル名 CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; 列の文字セットを変更する ALTER TABLE テーブル名 CHANGE フィールド名 フィールド名 フィールドの元のデータ型 CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci; 上記の 3 つのオプションは、実際の状況に応じて変更できます。 2. MySQL設定変数を表示する SHOW VARIABLES WHERE Variable_name LIKE 'character_set_%' OR Variable_name LIKE 'collation%'; character_set_server 変数の値が utf8mb4 と等しいかどうかを確認します。等しくない場合は、手順 3 を参照してください。 3. MySQL設定ファイルを変更する ここで、mysql は CentOS にインストールされ、構成ファイル名は my.cnf であり、パスはインストールしたディレクトリに基づいています。 vim /etc/my.cnf /etc/mysql/my.cnf マイ.cnf character_set_server を見つけて、その値を utf8mb4 に設定し、保存して終了します。再度挿入してエラーがあるかどうかを確認します。エラーがある場合は、MySQL サービスを再起動する必要があります。 サービスmysqldを再起動 要約する 上記はこの記事の全内容です。この記事の内容が皆さんの勉強や仕事に一定の参考学習価値を持つことを願っています。ご質問があれば、メッセージを残してコミュニケーションしてください。123WORDPRESS.COM を応援していただきありがとうございます。 以下もご興味があるかもしれません:
|
<<: Linux 3.X/4.x/5.x でパゴダ パネルのパスワードを忘れた場合の解決方法
>>: Vue は better-scroll を使用して水平スクロール方法の例を実現します
仮想マシンを使用しているときに、ディスク容量が不足し、継続使用するためにディスクをマウントする必要が...
1. インストールと使用まず、Vue プロジェクトにインストールします。 npm インストール --...
1. 複製原理マスター サーバーはバイナリ ログ ファイルに更新を書き込み、ログのローテーションを追...
1. パーティションテーブルの意味パーティション テーブル定義は、任意のサイズに設定できるルールに従...
目次序文🌟 1. APIの紹介2. 複数のデータソースの監視3. リスニングアレイ4. 監視対象5....
123WORDPRESS.COM HTML チュートリアル セクションに戻るには、ここをクリックして...
序文システムの高可用性を満たすためには、通常、クラスターを構築する必要があります。ホストがクラッシュ...
目次マインドマップとは何ですか? F6で描く方法アリペイ微信要約するマインドマップとは何ですか?マイ...
目的: ステーションAをステーションBのセカンダリディレクトリとして扱うのように: http://w...
一般的な CSS コードでは、UI レイアウトや互換性に関して軽微な問題が発生するだけです。しかし、...
原因このブログを書いた理由は、今日Leetcodeの日課問題をやっていたからです。文字列を整数(at...
序文パーティション フィールドは主キーの一部でなければならないことは誰もが知っています。では、複合主...
1. 問題時々Mysqlにログインしてパスワードを入力すると、この状況が発生しますmysql -u...
1. コンテナを作成して実行するdocker run -it --rm centos:latest ...
問題: MySQLテーブル内の自動増分IDのオーバーフローによりビジネスブロックが発生した背景: t...