登录
首页 >  数据库 >  MySQL

MySQL LENGTH() 函数如何测量字符串长度?

来源:tutorialspoint

时间:2023-08-26 20:46:45 183浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《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)

今天关于《MySQL LENGTH() 函数如何测量字符串长度?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>