LENGTH()返回字节长度,CHAR_LENGTH()返回字符个数;如’你好’在UTF8下LENGTH为6,CHAR_LENGTH为2;常用于验证存储大小或限制字节长度。

在 MySQL 中,LENGTH() 函数用于计算字符串的字节长度,而不是字符个数。这个区别在处理多字节字符(如中文、emoji)时尤为重要。
LENGTH() 的基本用法
使用 LENGTH(str) 可以返回字符串 str 所占用的字节数。例如:
SELECT LENGTH('hello'); -- 返回 5SELECT LENGTH('你好'); -- 返回 6(UTF8 编码中每个中文字符占 3 字节)SELECT LENGTH(''); -- 返回 0(空字符串)
与 CHAR_LENGTH() 的区别
很多人容易混淆 LENGTH() 和 CHAR_LENGTH():
LENGTH():返回字节长度CHAR_LENGTH():返回字符个数
举例说明:
疯狂翻译师App
支持屏幕、图片、视频字幕、文档、漫画等多种翻译,准确率高,操作简单。
104 查看详情
SELECT LENGTH('MySQL') AS byte_len, CHAR_LENGTH('MySQL') AS char_len; -- 都是 5SELECT LENGTH('中国') AS byte_len, CHAR_LENGTH('中国') AS char_len; -- byte_len=6, char_len=2
实际应用场景
当你需要验证字段存储大小、限制输入字节长度(如某些协议要求)或分析数据存储开销时,LENGTH() 很有用。
比如检查用户昵称是否超过 20 个字节:
SELECT nickname FROM users WHERE LENGTH(nickname) > 20;
基本上就这些。记住:LENGTH 看的是字节,不是字符个数,特别是在使用 UTF8 或 UTF8MB4 字符集时要特别注意。
以上就是mysql如何使用length计算字符串长度的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/726176.html
微信扫一扫
支付宝扫一扫