mysql 长度存储汉字,MySQL中 varchar(12) 可以存储多少个汉字

一、length(str) 和 char_length(str) 的区别

1、length(str)

返回字符串 str 的长度,单位为字节。一个多字节字符算作多字节。

2、char_length(str)

返回字符串 str 的长度,单位为字符。一个多字节字符算作一个单字符。

这意味着对于一个包含5个2字节字符的字符串,length()的返回值是 10,而 char_length() 的返回值则为 5。

二、UTF-8 编码与 GBK 编码的区别

1、UTF8 编码数据表

(1)创建表CREATE TABLE `my_test_utf8` (

`my_id` int(11) NOT NULL AUTO_INCREMENT,

`my_name` varchar(12) DEFAULT NULL,

PRIMARY KEY (`my_id`)

) ENGINE=MyISAM AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='my_test  UTF8';

(2)插入一条数据:

92d152273a94669e51c898caa34c49fe.png

(3)检索长度SELECT length(my_name), char_length(my_name), my_name FROM `my_test_utf8` where my_id=1;

返回值如下:

2878f414f6a4ffc6dfb475cdbf886a18.png

2、GBK 编码的数据表

(1)创建表CREATE TABLE `my_test_gbk` (

`my_id` int(11) NOT NULL AUTO_INCREMENT,

`my_name` varchar(12) DEFAULT NULL,

PRIMARY KEY (`my_id`)

) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=gbk COMMENT='my_test GBK';

(2)插入一条数据:

3a6b5f36888f12dac4c140fa0e1ae25e.png

(3)检索长度SELECT length(my_name), char_length(my_name), my_name FROM `my_test_gbk` where my_id=1;

返回值如下:

290964ffb3f43a3315cb78a9ecbf4b2e.png

三、总结

对于 UTF8 编码,一个汉字,即一个字符,占 3 个字节。

对于 GBK 编码,一个汉字,即一个字符,占 2 个字节。

MySQL 4.0 版本以下,以字节解释长度。

MySQL 5.0 版本以上,以字符解释长度。

所以 varchar(12) 可存储 12 个汉字,即 12 个字符。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值