mysql innodb utf8_mysql innodb表 utf8 gbk占用空间相同,毁三观

博主通过实验发现UTF-8与GBK编码在MySQL中占用的空间大小与理论不符,无论纯英文、纯中文还是中英文混合,两种编码占用的空间大小一致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

昨天因为发生字符集转换相关错误,今天想验证下utf8和gbk中英文下各自空间的差距。这一测试,绝对毁三观,无论中文还是中文+英文,gbk和utf8占用的实际物理大小完全相同,根本不是理论上所述的“UTF-8对中文采用3个字节,对英文采用1个字节,GBK对中英文都采用2个字节”,如下所示:

空表:

8e267948797e5ebb658ca0e0ba8aef28.png

GBK如下:

CREATE TABLE `test_char_gbk` (

`gbk_str` varchar(100) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=gbk;

INSERT INTO test_char_gbk VALUES(‘ffhpf2fhfh2hfh32h82h832h328fhf28fh3283h83h8h82h382‘);

insert into test_char_gbk select * from test_char_gbk

共 65536 行受到影响

0acc6be18d6d406cb25fec2b13a6f36a.png

97ea0f81ba546f700933d74a7ecd2497.png

UTF8:

CREATE TABLE `test_char_utf8` (

`utf8_str` varchar(100) DEFAULT NULL

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

INSERT INTO test_char_utf8 VALUES(‘ffhpf2fhfh2hfh32h82h832h328fhf28fh3283h83h8h82h382‘);

insert into test_char_utf8 select * from test_char_utf8

共 65536 行受到影响

b2857d8db23f94fffc46b7449850f675.png

c4828bcb38fe3138975322f72995990a.png

=============再看中英文结合,实际大多也是结合=============

TRUNCATE TABLE test_char_utf8;

INSERT INTO test_char_utf8 VALUES(‘ffhpf2fhfh2hfh32h82h832h328fhf28fh3283h83h8h82h382‘);

INSERT INTO test_char_utf8 VALUES(‘中国中国中国中国中国中国‘);

insert into test_char_utf8 select * from test_char_utf8

共 65536 行受到影响

de5d0151cb5533deecbb655156317724.png

truncate table test_char_gbk;

INSERT INTO test_char_gbk VALUES(‘ffhpf2fhfh2hfh32h82h832h328fhf28fh3283h83h8h82h382‘);

INSERT INTO test_char_gbk VALUES(‘中国中国中国中国中国中国‘);

insert into test_char_gbk select * from test_char_gbk

共 65536 行受到影响

07a727c767b8343ae8e7b0802a63266b.png

我去。。。。。没这么玩的。。。。

原文:http://www.cnblogs.com/zhjh256/p/5779296.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值