MySQL 的 LENGTH() 函数如何测量字符串长度?
MySQL LENGTH() 函数以“字节”为单位测量字符串长度,这意味着它不是多字节安全的。多字节安全函数(如 CHAR_LENGTH() 或 CHARACTER_LENGTH())与 LENGTH() 函数的结果差异,尤其体现在 Unicode 中(大多数字符使用两个字节编码)或 UTF-8 中(字节数可变)。例如,如果一个字符串包含四个 2 字节字符,则 LENGTH() 函数将返回 8,而 CHAR_LENGTH() 或 CHARACTER_LENGTH() 函数将返回 4。如下例所示:
示例
mysql> Select LENGTH('tutorialspoint');
+--------------------------+
| LENGTH('tutorialspoint') |
+--------------------------+
| 14 |
+--------------------------+
1 row in set (0.00 sec)上述结果集显示字符串“tutorialspoint”的长度为 14,因为它尚未转换为 Unicode 字符。以下查询将其转换为 Unicode 字符:
mysql> SET @A = CONVERT('tutorialspoint' USING ucs2);
Query OK, 0 rows affected (0.02 sec)将字符串转换为 Unicode 后,结果为 28 而不是 14,因为在 Unicode 中,单个字符占用 2 个字节,如下所示:
mysql> Select LENGTH(@A); +------------+ | LENGTH(@A) | +------------+ | 28 | +------------+ 1 row in set (0.00 sec)
但是 CHAR_LENGTH() 返回的结果为 14,因为它是一个多字节安全函数,如下所示:
mysql> Select CHAR_LENGTH(@A); +-----------------+ | CHAR_LENGTH(@A) | +-----------------+ | 14 | +-----------------+ 1 row in set (0.00 sec)
广告
数据结构
网络
关系数据库管理系统 (RDBMS)
操作系统
Java
iOS
HTML
CSS
Android
Python
C语言编程
C++
C#
MongoDB
MySQL
Javascript
PHP