关于vachar存储汉字数量的问题

本文详细介绍了数据库中varchar类型的存储规则,区分了MySQL4.0版本以下和5.0版本以上的区别。在5.0版本及以上,varchar(100)可存储100个字符,无论数字、字母还是UTF8汉字。通过创建表和插入数据的示例,展示了varchar(20)的限制,超过限制会报错。此外,对比了char与varchar在存储固定和可变长度数据时的不同。
摘要由CSDN通过智能技术生成

具体还是要看版本的

4.0版本以下,varchar(100),指的是100字节,如果存放UTF8汉字时,只能存33个(每个汉字3字节)

5.0版本以上,varchar(100),指的是100字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放100个。

自己在数据库中建个表测试下可以放多少个汉字。

示例:以5.0以上版本为例。
新建表:

CREATE TABLE varchar_test (
`id` int(11) NOT NULL ,
`string` varchar(20)
) ENGINE=InnoDB
DEFAULT CHARACTER SET=utf8COLLATE=utf8_general_ci

插入表

INSERT INTO varchar_test (id, string)
VALUES (1, '一二三四五六七八九十');

INSERT INTO varchar_test (id, string)
VALUES (2, '一二三四五六七八九十一二三四五六七八九十');

INSERT INTO varchar_test (id, string)
VALUES (3, '12345678901234567890');

测试结果:

1:一二三四五六七八九十
2:一二三四五六七八九十一二三四五六七八九十
312345678901234567890

如果插入字符超过21个,则报错

INSERT INTO varchar_test (id, string)
VALUES (3, '123456789012345678901');

[Err] 1406 - Data too long for column'string' at row 1

char(5):长度是固定的5,无论存储的数据是否达到5
vachar(5):存储长度是可变的,5只是意味着最长的长度为5

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值