MySQL LENGTH() 関数と CHAR_LENGTH() 関数の違いは何ですか?

WBOY
リリース: 2023-09-02 16:57:07
転載
1156 人が閲覧しました

MySQL LENGTH() 和 CHAR_LENGTH() 函数有什么区别?

これらの関数は両方とも文字列関数であり、文字列内に存在する文字数を返します。ただし、CHAR_LENGTH() 関数は文字列の長さを「文字」で測定するのに対し、LENGTH() 関数は文字列の長さを「バイト」で測定するという点が異なります。言い換えれば、CHAR_LENGTH() 関数はマルチバイト セーフである、つまり文字がシングルバイトであるかマルチバイトであるかを無視すると言えます。たとえば、文字列に 4 つの 2 バイト文字が含まれる場合は、LENGTH() となります。

この関数は 8 を返しますが、CHAR_LENGTH() 関数は 4 を返します。この意味で、CHAR_LENGTH() は LENGTH() 関数よりも正確な結果を与えると言えます。

この違いは、ほとんどの文字が 2 バイトでエンコードされる Unicode と、バイト数が異なる UTF-8 に特に関係します。次の例は、次のことを示しています。

Example

次の例では、まず、文字列「Gaurav」が ucs2 strong>、つまり Unicode に変換され、2 バイトの文字、文字セットが節約されます。 。次に、結果セットの違いを観察できます。つまり、LENGTH() はバイト単位の長さを返しますが、CHAR_LENGTH() は文字単位の長さを返します。

mysql> SET @A = CONVERT('Gaurav' USING ucs2);
Query OK, 0 rows affected (0.15 sec)

mysql> Select Char_length(@A), LENGTH(@A);

+-----------------+------------+
| Char_length(@A) | LENGTH(@A) |
+-----------------+------------+
| 6               | 12         |
+-----------------+------------+

1 row in set (0.03 sec)
ログイン後にコピー

次の例では、UTF-8 の特殊文字を使用していますが、文字セットのバイト数が異なります。その後、結果セットからの違いを観察できます。

えええええ

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

ソース:tutorialspoint.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート