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)

更新日期: 2020-06-20

201 次浏览

开启你的 事业

完成课程即可获得认证

开始学习
广告