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

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 行受到影响


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 行受到影响


=============再看中英文结合,实际大多也是结合=============
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 行受到影响

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 行受到影响

我去。。。。。没这么玩的。。。。
mysql innodb表 utf8 gbk占用空间相同,毁三观的更多相关文章
- 【记录】mysql中建表utf8和utf8mb4区别?timestamp和datetime区别?
		mysql中建表utf8和utf8mb4区别? 1:utf8 是 Mysql 中的一种字符集,只支持最长三个字节的 UTF-8字符,也就是 Unicode 中的基本多文本平面 2:要在 Mysql 中 ... 
- MySQL InnoDB表--BTree基本数据结构
		MySQL InnoDB表是索引组织表这一点应该是每一个学习MySQL的人都会首先学到的知识,这代表这表中的数据是按照主键顺序存储,也就是说BTree的叶子节点存储了所有该行的数据. 我最开始是搞Or ... 
- MySQL InnoDB表压缩
		MySQL InnoDB表压缩 文件大小减小(可达50%以上) ==> 查询速度变快(count * 约减少20%以上时间) 如何设置mysql innodb 表的压缩: 第一,mysql的版本 ... 
- MySQL InnoDB表和索引之聚簇索引与第二索引
		MySQL InnoDB表和索引之聚簇索引与第二索引 By:授客QQ:1033553122 每个InnoDB表都有一个称之为聚簇索引(clustered index)的特殊索引,存储记录行数据.通常, ... 
- MySQL innodb表使用表空间物理文件复制或迁移表
		MySQL InnoDB引擎的表通过拷贝物理文件来进行单表或指定表的复制,可以想到多种方式,今天测试其中2种: 将innodb引擎的表修改为Myisam引擎,然后拷贝物理文件 直接拷贝innodb的表 ... 
- Mysql Innodb 表碎片整理
		一.为什么会产生碎片 简单的说,删除数据必然会在数据文件中造成不连续的空白空间,而当插入数据时,这些空白空间则会被利用起来.于是造成了数据的存储位置不连续,以及物理存储顺序与理论上的排序顺序不同,这种 ... 
- MySQL Innodb表空间不足的处理方法
		官方给出的解决方案: 添加和删除 InnoDB 数据和日志文件 这一节描述在InnoDB表空间耗尽空间之时,或者你想要改变日志文件大小之时,你可以做的一些事情. 最简单的,增加InnoDB表空间大小的 ... 
- MySQL InnoDB表的碎片量化和整理(data free能否用来衡量碎片?)
		网络上有很多MySQL表碎片整理的问题,大多数是通过demo一个表然后参考data free来进行碎片整理,这种方式对myisam引擎或者其他引擎可能有效(本人没有做详细的测试).对Innodb引擎是 ... 
- MySQL InnoDB表空间加密
		从 MySQL5.7.11开始,MySQL对InnoDB支持存储在单独表空间中的表的数据加密 .此功能为物理表空间数据文件提供静态加密.该加密是在引擎内部数据页级别的加密手段,在数据页写入文件系统时加 ... 
随机推荐
- springmvc下使用kaptcha做验证码
			http://www.open-open.com/lib/view/open1395238908947.html 
- 检索 COM 类工厂中 CLSID 为 {13C28AD0-F195-4319-B7D7-A1BDAA329FB8} 的组件时失败,原因是出现以下错误: 80040154
			异常类型:COMException 异常消息:检索 COM 类工厂中 CLSID 为 {13C28AD0-F195-4319-B7D7-A1BDAA329FB8} 的组件时失败,原因是出现以下错误: ... 
- apache.http.MalformedChunkCodingException: Chunked stream ended unexpectedly
			产生的原因,应该是服务器返回的数据不是规范的格式 .我使用的xutils的httpUtils来实现网络通信的,关于读取数据是在 StringDownloadHandler类中源代码 inputStre ... 
- Log4Net 手册
			首先感慨下,现在的程序员做的工作因为高级语言的生产力,系统框架模式的成熟,开源大牛的贡献,已经成越来越偏向 “面向配置编程”了...... 详细使用指南见文章:http://blog.csdn.net ... 
- unity4.6 failed to update unity web player
			unity4.6 failed to update unity web player 新升级的 4.6.2P2 版本修复了IOS很多的bug. 但突然发现导出的Web版本反而不能工作了. “faile ... 
- ActivityGroup里面装的子Activity不执行OnActivityResult()的解决办法
			转自http://blog.csdn.net/snakewarhead/article/details/7976831 tab activity 中调用startActivityForResult 以 ... 
- 【.Net底层剖析】2.stfld指令-给对象的字段赋值
			.Net底层剖析目录章节 1.[深入浅出.Net IL]1.一个For循环引发的IL 2.[.Net底层剖析]2.stfld指令-给对象的字段赋值 3.[.Net底层剖析]3.用IL来理解属性 引言: ... 
- [IR] Evaluation
			无序检索结果的评价方法: Precision P = tp/(tp + fp) Recall R = tp/(tp + fn) Accuracy = (tp + tn) ... 
- RPM安装命令总结--转载
			原地址:http://www.cnblogs.com/zqwang0929/p/3352237.html 在 Linux 操作系统下,几乎所有的软件均通过RPM 进行安装.卸载及管理等操作.RPM 的 ... 
- 【转载】Linux下编辑生成.mo文件
			转载自:http://www.hackbase.com/tech/2012-02-27/65972.html 编辑生成.mo文件 我们在弄网站的时候很可能会接触到.mo和.po文件..po文件是GNU ... 
