MySQL における length() と char_length() の違いを理解する
MySQL では、2 つの重要な文字列関数 length() と char_length () は、データの処理に大きな影響を与える可能性のある根本的な違いを示し、 storage.
主な違いは何ですか?
length() は文字列の長さをバイト単位で測定し、char_length() は文字列の長さを測定します。この区別は、個々の文字が複数バイトを占める可能性がある Unicode 文字列または UTF-8 でエンコードされた文字列を扱う場合に重要になります。
文字列をバイナリとして保存する実際的な理由
バイナリ文字列ストレージがなぜ有利であるかはすぐには分からないかもしれませんが、特定のシナリオではバイナリ文字列ストレージが必要になります。 use:
例:
を検討してください。 MySQL の違いを示す次の例:
mysql> select length('MySQL'), char_length('MySQL'); +-----------------+----------------------+ | length('MySQL') | char_length('MySQL') | +-----------------+----------------------+ | 5 | 5 | +-----------------+----------------------+ 1 row in set (0.01 sec)
この例では、両方の関数が同じ値を返します。 (5) 「MySQL」の文字はすべて半角文字であるため。ただし、ユーロ記号 (€) などの Unicode 文字を使用すると、結果は異なります。ユーロ記号は 3 バイトを使用して UTF-8 でエンコードされるため、
select length(_utf8 '€'), char_length(_utf8 '€') --> 3, 1
length() は 3 バイトを返します。一方、char_length() は 1 文字を返します。
データベース操作を最適化し、確実にデータの正確性。
以上がMySQL の Length() と char_length(): 主な違いは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。