Mysql 计算字符串的长度

Mysql 计算字符串的长度

MySQL中char_length(str),length(str)都属于判断长度的内置函数,根据其得到字符串的长度;

char_length(str)

计算单位:字符

不管汉字还是数字或者是字母都算是一个字符

length(str)

计算单位:字节

utf8编码:一个汉字三个字节,一个数字或字母一个字节。

gbk编码:一个汉字两个字节,一个数字或字母一个字节。

length()<>char_length()可以用来检验是否含有中文字符

扩展:

MySQL5.0.3版本之后varchar类型大小的计算方式有所变化,从最早的按字节算大小varchar(length)改成了varchar(char_length)。

1)MySQL 5.0.3 之前:

数据类型大小:0--255字节

详解:varchar(20)中的20表示字节数,如果存放utf-8编码的话只能放6个汉字。varchar(n),这里的n表示字节数。

2)MySQL 5.0.3之后:

数据类型大小:0--65535字节,但最多占65532字节(其中需要用两个字节存放长度,小于255字节用1个字节存放长度)

详解:varchar(20)表示字符数,不管什么编码,不管是英文还是中文都可以存放20个。

参考:https://blog.csdn.net/qq_39390545/article/details/106618423

相关推荐
千寻技术帮6 分钟前
10334_基于Web的文学书刊服务平台
mysql·ssm·源码·代码·文学书刊
l1t8 分钟前
用SQL执行累计值汇总的几种方法
数据库·sql·postgresql·duckdb
踢足球092937 分钟前
寒假打卡:2026-2-3
数据库
每次学一点39 分钟前
【ZeroTier自研之路】planet的组成
服务器·网络·数据库
策知道1 小时前
2026年北京政府工作报告产业指标深度解析
大数据·数据库·人工智能·搜索引擎·政务
Traced back1 小时前
# C# WinForms 数据库清理系统基础知识与避坑指南
开发语言·数据库·c#
云边有个稻草人2 小时前
金仓 VS MongoDB:国产数据库凭什么成为MongoDB平替首选?
数据库·mongodb·国产数据库·金仓·kingbasees sql
DarkAthena2 小时前
【GaussDB】排查创建索引后查询数据行数发生变化的问题
数据库·sql·gaussdb
MengFly_2 小时前
Compose 脚手架 Scaffold 完全指南
android·java·数据库
PPPPickup2 小时前
application.yml或者yaml文件不显示绿色问题
java·数据库·spring