mysql varchar(n) n表示字符个数

(注:以下针对mysql 5.0以上版本)

mysql varchar(n)  n表示字符个数,不是字节数。

对于utf8编码,无论是字符、数字、汉字均占3字节。

varchar最大长度为65535个字节,最大可存储汉字数 = (65535-1-2)/3
减1是因为实际存储从第2个字节开始
减2是因为要在列表长度存储实际字符长度

除3是因为utf8编码限制。


例:1.验证varchar(n)表示汉字

CREATE TABLE `t1` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(10) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

例:2. n表示字符,那么varchar(n)中n的最大值应该为: 

n = (65535-1-2-4)/3=21842.67 = 21843
减1和减2与上例相同;
减4的原因是int类型的id占4个字节;

编码是utf8



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值