mysql varchar长度固定_mysql 数据库中varchar的长度与字节,字符串的关系

MySQL VARCHAR字段的长度与字节数有直接关系,例如VARCHAR(5)能存储5个字符,不受数字、字母或汉字限制。最大长度计算公式为(65535-1-2-4)/3,考虑了行定义长度、头部字节和INT字段占用。在选择数据类型时,固定长度使用CHAR,变化长度使用VARCHAR,超过255字符考虑VARCHAR或TEXT。
摘要由CSDN通过智能技术生成

CREATE TABLE `test` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT,

`content` varchar(5) NOT NULL DEFAULT '',

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8 COLLATE=utf8_general_ci;

INSERT INTO `test`(`content`) VALUES ('123456');

INSERT INTO `test`(`content`) VALUES ('中国人民银行');

SELECT * FROM `test`;

返回:

id content

1 12345

2 中国人民银

可见,varchar(5)能存储5个字符,不管是数字,字母,还是汉字.

CREATE TABLE `test2` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT,

`content` varchar(21842) NOT NULL DEFAULT '',

PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=0 DEFAULT CHARSET=utf8 COLLATE=utf8_general_ci;

该表中varchar类型的字段能容纳的最大字符数2

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值