MySQL の文字セット utf8 を utf8mb4 に変更する方法

MySQL の文字セット utf8 を utf8mb4 に変更する方法

MySQL 5.5 の場合、文字セットが設定されていない場合、MySQL のデフォルトの文字セットは latin1 ラテン文字セットになります。

しかし、さまざまなビジネスのさらなる発展に伴い、さまざまな国の母国語の文字に加えて、いくつかの絵文字がアプリケーションに頻繁に登場しています。MySQL 5.5より前のUTF-8エンコーディングは1〜3バイトのみをサポートし、BMP部分のUnicodeエンコーディング領域をサポートしていましたが、MySQL 5.5からは4バイトのUTFエンコーディングutf8mb4をサポートできるようになりました。1つの文字でより多くの文字セットとより多くの絵文字をサポートできます。

utf8mb4 は utf8 と互換性があり、utf8 よりも多くの文字を表現できます。これは utf8 文字セットのスーパーセットです。そのため、ISO などの一部の新しいビジネスでは、MySQL データベースの文字セットを utf8mb4 に設定します。

今日、アプリケーション要件を処理しているときに、次のような問題に遭遇しました。

もちろん、クライアント側でMySQLデータベースの文字セットをutf8mb4に変更するのが最も良い調整方法ですが、これには多くの変更が伴い、クライアントの一部をutf8に変更し、一部をutf8mb4に変更すると混乱が生じる可能性があります。

いくつかのテストの後、MySQL データベースの my.cnf の文字セット構成が次の構成に変更されました。

[クライアント] 
デフォルトの文字セット=utf8mb4 
 
[mysqld] 
文字セットサーバー = utf8mb4 
照合サーバー = utf8mb4_unicode_ci 
init_connect = '名前をutf8mb4に設定' 
文字セットクライアントハンドシェイクをスキップ = true 
 
[mysql] 
デフォルトの文字セット = utf8mb4

MySQL 文字セットの使用に関する推奨事項

• データベース/テーブルを作成し、データベース操作を実行するときは、MySQL のデフォルト設定に頼るのではなく、使用する文字セットを明示的に指定するようにしてください。そうしないと、MySQL をアップグレードするときに大きな問題が発生する可能性があります。

• データベースと接続文字セットの両方が latin1 を使用すると、ほとんどの場合、文字化けは解決されますが、文字単位で SQL 操作を実行できないという欠点があります。一般的には、データベースと接続文字セットの両方を utf8 に設定する方がよいでしょう。

• mysql C API を使用する場合は、データベース ハンドルを初期化した直後に、mysql_options を使用して MYSQL_SET_CHARSET_NAME 属性を utf8 に設定します。この方法では、SET NAMES ステートメントで接続文字セットを明示的に指定する必要はなく、mysql_ping を使用して切断された長い接続に再接続すると、接続文字セットも utf8 にリセットされます。

• MySQL PHP API の場合、ページレベルの PHP プログラムの合計実行時間は一般的に短くなります。データベースに接続した後、SET NAMES ステートメントを使用して接続文字セットを 1 回明示的に設定できます。ただし、長い接続を使用する場合は、必ず接続を開いたままにして、切断して再接続した後に SET NAMES ステートメントを使用して接続文字セットを明示的にリセットしてください。

MySQL における utf8 と utf8mb4 の違いについての包括的な理解: https://www.jb51.net/article/90037.htm

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • Linux システムで MySQL の文字セットを UTF8 に変更する手順
  • MySQL での utf8mb4 照合の例
  • MySQL エンコーディング utf8 および utf8mb4 utf8mb4_unicode_ci および utf8mb4_general_ci
  • MySQL データベースのエンコーディングを utf8mb4 に変更する方法
  • mysql charset=utf8 本当に意味が分かりますか
  • mysql 文字化けした文字 latin1 文字を UTF8 に変換 詳細

<<:  Centos7 esxi6.7 テンプレートの実際のアプリケーションの詳細な説明

>>:  WeChatアプレットがシンプルな計算機機能を実装

推薦する

Web アプリ開発時間を短縮する 10 の時間を節約するヒント (グラフィカル チュートリアル)

今日の開発環境では、速いほど良いです。 「迅速なアプリケーション開発」、「アジャイル ソフトウェア開...

Vueのドラッグスクリーンショット機能を実装する簡単な方法

マウスをドラッグしてページのスクリーンショットを撮ります(指定した領域にスクリーンショットをドラッグ...

MySQL ジョイントテーブル更新デー​​タの詳細な例

1.MySQL UPDATE JOIN構文MySQL では、UPDATE ステートメントでJOIN句...

VueはTeleportをベースにModalコンポーネントを実装します

目次1. テレポートについて知る2. テレポートの基本的な使い方3. 最初のステップの最適化4. 第...

JS でカルーセル効果を実現する 3 つの簡単な方法

この記事では、JSカルーセル効果の具体的なコードを実現するための3つの方法を紹介します。具体的な内容...

Mysql のデッドロックの表示とデッドロックの除去の詳細な説明

序文しばらく前にMysqlのデッドロック問題に遭遇したので、解決しました。問題の説明: Mysql ...

Linux Dig コマンドの使用法

発掘紹介: Dig は、Unix ライクなコマンドライン モードで NS レコード、A レコード、M...

Mybatis+mysqlはストアドプロシージャを使用してシリアル番号実装コードを生成します。

同時操作によるデータの重複を避けるために、データベースを操作するときにストアドプロシージャを使用して...

JavaScriptの基礎を学ぶ

目次1. JavaScriptを記述する場所2. JavaScriptでよく使われる入力文と出力文1...

TypeScriptの基本型の詳細な説明

目次ブール型数値型文字列型文字列と数値を連結する未定義およびnull配列型タプル型列挙型あらゆるタイ...

tdが空の場合に境界線を表示する方法

以前、CSS を使用してテーブルの border + bordercolordark + borde...

Linux で実行中のすべてのプロセスを表示する方法

ps コマンドを使用できます。プロセスの PID など、現在実行中のプロセスに関する関連情報を表示で...

本番環境でのMySQLパラメータsql_safe_updatesの使用に関する詳細な説明

序文アプリケーションのバグや DBA の誤操作が発生した場合、テーブル全体が更新される可能性がありま...

MySQL クロステーブルクエリとクロステーブル更新

SQL の基礎知識がある友人は、「クロステーブル クエリ」について聞いたことがあるはずですが、クロス...

完全なMySQL学習ノート

目次MyISAM と InnoDBパフォーマンスの低下と SQL の速度低下の理由: MySQL 実...