zoukankan      html  css  js  c++  java
  • 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 行受到影响

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

  • 相关阅读:
    函数
    拉取代码到本地
    逻辑位运算符 以及 布尔运算符&&、||
    JS中substr与substring的区别
    ? :和!:的用法含义及es6语法...
    JS中attribute和property的区别
    并发、并行的理解
    斑鸠云商小程序记住账号和密码
    js中的foreach用法
    指针与数组
  • 原文地址:https://www.cnblogs.com/zhjh256/p/5779296.html
Copyright © 2011-2022 走看看