mysql中储存的问题 与 utf8字符集的理解

问题1: int(10)只能存储 10个长度的数字,int(11)就会存储 11 个长度的数字的疑问
问题2: varchar(100) 与 varchar(150)的区别
问题3: UTF8字符集来源与字符字节的关系
问题4: 时间戳用int储存 最大能存多少
问题5: 储存数据的一些建议
围绕这几个疑惑自己去学习并一下做总结

首先了解一下基本概念

名称单位描述详情
bit计算机内部数据储存的最小单位数据存储单位Bit(比特)是binary digit的英文缩写,量度信息的单位,也是表示信息量的最小单位,只有0、1两种二进制状态。
字节byte计算机中 数据处理 的基本单位,习惯上用大写 B 来表示8个位构成一个字节; 即:1 byte (字节)= 8 bit(位) 另外: 千字节(KB)<兆字节(MB)<吉字节(GB)<太字节(TB)<拍字节(PB)<艾字节(EB)<泽字节(ZB)<尧字节(YB)<珀字节(BB)<诺字节(NB)<刀字节(DB)
字符字符是指计算机中使用的字母、数字、字和符号 a、A、中、+、*、の…均表示一个字符utf-8 编码下,一个汉字 字符 占用 3 个 字节; gbk 编码下,一个汉字 字符 占用 2 个 字节;
字符集编码utg-8;gbk2312;ASCii;Unicode规定每个“字符”分别用一个字节还是多个字节存储,用哪些字节来存储,这个规定就叫做“编码”。(其实际是对字符集中字符进行编码,即:每个字符用二进制在计算中表示存储);

字符集的故事

美国人发明了电脑 ,有了二进制编程(0,1) 为了表示字母与符号创建了ASCII字符集,有96个打印字符,和32个控制字符组成;一共96+32=128个.
但全世界有上百种语言,日本把日文编到 Shift_JIS 里,韩国把韩文编到Euc-kr 里,各国有各国的标准,就会不可避免地出现冲突,结果就是,在多语言混合的文本中,显示出来会有乱码为了避免各国之间的编码冲突,Unicode应运而生。
Unicode把所有语言都统一到一套编码里,这样就不会再有乱码问题了。新的问题又出现了:如果统一成Unicode编码,乱码问题从此消失了。
但是,如果你写的文本基本上全部是英文的话,用Unicode编码比ASCII编码需要多一倍的存储空间,在存储和传输上就十分不划算。
本着节约的精神,又出现了把Unicode编码转化为“可变长编码”的UTF-8编码。UTF-8编码把一个Unicode字符根据不同的数字大小编码成1-6个字节,常用的英文字母被编码成1个字节,汉字通常是3个字节,只有很生僻的字符才会被编码成4-6个字节。如果你要传输的文本包含大量英文字符,用UTF-8编码就能节省空间
从上面的表格还可以发现,UTF-8编码有一个额外的好处,就是ASCII编码实际上可以被看成是UTF-8编码的一部分。 如果把ASCII编码的A用Unicode编码,只需要在前面补0就可以,因此,A的Unicode编码是00000000 01000001。
搞清楚了ASCII、Unicode和UTF-8的关系,我们就可以总结一下现在计算机系统通用的字符编码工作方式:
1.在计算机内存中,统一使用Unicode编码,当需要保存到硬盘或者需要传输的时候,就转换为UTF-8编码。
2.用记事本编辑的时候,从文件读取的UTF-8字符被转换为Unicode字符到内存里,编辑完成后,保存的时候再把Unicode转换为UTF-8保存到文件。

ASCII码: 
					1个英文字母(不分大小写)= 1个字节的空间
                    1个中文汉字 = 2个字节的空间
                    1个ASCII码 = 一个字节
UTF-8编码:
					1个英文字符 = 1个字节
                     英文标点  = 1个字节
                     1个中文(含繁体) = 3个字节
                     中文标点 = 3个字节
Unicode编码:
					1个英文字符 = 2个字节
                     英文标点  = 2个字节
                     1个中文(含繁体) = 2个字节
                     中文标点 = 2个字节

自我理解解答问题

int就是占四个字节,一个字节 8 位,也就是4*8=32,可以表示的数字个数是 2的 32 次方(2^32 = 4 294 967 296个数字)。所以在mysql中储存 :int默认是十位的长度,在计算机中占四个字节32位
总结:
int(M) 中的M指示最大显示宽度,最大有效显示宽度是 255,且显示宽度与存储大小或类型包含的值的范围无关。

mysql数值型对于字符型varchar(100)

要看mysql版本:
4.0版本以下,varchar(100),指的是100字节,如果存放UTF8汉字时,只能存33个(每个汉字3字节) 
5.0版本以上,varchar(100),指的是100字符,无论存放的是数字、字母还是UTF8汉字(每个汉字3字节),都可以存放100个。

对于时间戳用int储存

mysql int 有符号位 支持的最大长度是 2147483647; 而2038-01-19 11:14:07(北京时间) 已经达到了最大存储值, 所以之后的时间会被截取

解决办法:
    更新类型 bigint, 我的项目账号数量不是特别大,所以可以这样做,也不特别占用空间
    存Ymd的形式

关于在mysql中储存的知识点

tinyint(1)  和 tinyint(3) 没什么区别,占用字节都是一位,存储范围都是一样的

tinyint(3) zerofill ,当插入的数据少于3位的时候,左边自动补零,这才是限制显示长度

int(1) 和 tinyint(1) ,够用的情况下,优先选择tinyint(1),因为占字节少、节省空间。

tinyint一个字节   smallint  两个字节   MEDIUMINT三个字节  int 4个字节  BIGINT 8个字节

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值