ホームページ  >  記事  >  データベース  >  mysqlのutf8とutf8mb4の違いは何ですか?

mysqlのutf8とutf8mb4の違いは何ですか?

不言
不言オリジナル
2018-08-22 10:00:531634ブラウズ

この記事では、mysql の utf8 と utf8mb4 の違いについて説明します。 、特定の参考値があり、困っている友人がそれを参照できます。お役に立てば幸いです。

1. はじめに

MySQL は 5.5.3 以降 utf8mb4 エンコーディングを追加しました。mb4 はほとんどのバイト 4 を意味し、4 バイトの Unicode と互換性を持つように特別に設計されています。幸いなことに、utf8mb4 は utf8 のスーパーセットであり、エンコーディングを utf8mb4 に変更する以外に他の変換は必要ありません。もちろん、スペースを節約するには、通常は utf8 を使用するだけで十分です。

2. コンテンツの説明

上で述べたように、utf8 はほとんどの漢字を格納できるのに、mysql でサポートされている utf8 エンコーディングの最大文字長が 3 バイトであることがわかります。ワイド文字が異常に挿入されます。 3 バイト UTF-8 でエンコードできる最大 Unicode 文字は 0xffff で、これは Unicode の Basic Multilingual Plane (BMP) です。言い換えれば、基本的なマルチテキスト プレーンにない Unicode 文字は、Mysql の utf8 文字セットを使用して保存することはできません。絵文字表現 (絵文字は iOS や Android スマートフォンで一般的な特別な Unicode エンコーディングです)、多くの珍しい漢字、および新しい Unicode 文字などが含まれます。

3. 問題の根本

元の UTF-8 形式は 1 ~ 6 バイトを使用し、最大 31 文字をエンコードできます。最新の UTF-8 仕様では、1 ~ 4 バイトのみを使用し、最大 21 ビットをエンコードできます。これは、17 の Unicode プレーンすべてを表すのにちょうど十分です。

utf8 は、Unicode の基本的なマルチテキスト プレーンである、最大 3 バイトの UTF-8 文字のみをサポートする Mysql の文字セットです。

Mysql の utf8 は、最大長が 3 バイトの UTF-8 文字のみをサポートするのはなぜですか?
しばらく考えてみましたが、Mysql が最初に開発されたとき、Unicode には補助プレーンがなかったからかもしれません。当時、Unicode 委員会はまだ「全世界には 65535 文字で十分である」という夢を抱いていました。 Mysql の文字列の長さは、バイトではなく文字数として計算されます。CHAR データ型の場合、文字列用に十分な長さを確保する必要があります。 utf8 文字セットを使用する場合、予約する必要がある長さは、utf8 の最長文字長に文字列長を乗算したものになります。したがって、当然、utf8 の最大長は 3 に制限されます。たとえば、CHAR(100) Mysql は予約します。 300バイト。後続のバージョンが 4 バイト長の UTF-8 文字をサポートしない理由については、1 つは下位互換性を考慮したためであり、もう 1 つは基本的な多言語プレーン以外の文字はほとんど使用されないためだと思います。

Mysql で 4 バイト長の UTF-8 文字を保存するには、utf8mb4 文字セットを使用する必要がありますが、これはバージョン 5.5.3 以降でのみサポートされます (バージョンを確認してください: select version();)。より良い互換性を得るには、常に utf8 ではなく utf8mb4 を使用する必要があると思います。 CHAR 型データの場合、Mysql 公式の推奨に従って、UTF8MB4 は CHAR の代わりに VARCHAR を使用します。

関連する推奨事項:

mysql で group_conca 関数の長さ制限を変更する方法

mysql の大きなテーブルでの count() の使用法と mysql での count() の最適化

以上がmysqlのutf8とutf8mb4の違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。