mysqlmediumint长度_mysql字段类型tinyint、smallint、me。
。。
mysql建模的过程中,对于优化来讲⼀个⾮常重要的点就是字段类型的设置,好的字段类型的设置可以帮助更快的查询数据同时能节约硬盘空间,这对于优化数据库来讲是⾮常重要的。
mysql的字段类型⼤体来讲分为int、text、varchar、char、blog等⼏种,⽽各⾃的类型中⼜划分了不同的字符数的类型,这⾥先来讨论⼏种整形的情况。
先来看⼀下基本的概念:字节(byte),1个字节等于8个位(bit),⼀个bit存储0或者1,理解这个对于理解后⾯的占⽤字节导致的存储数值的有很重要的作⽤。
整型,常见细分为tinyint、smallint、mediumint、int、bigint这⼏种。
1)tinyint:存储所占⼀个字节,⼀个字节等于8bit,根据1bit可以存储0到1两种可能性,因此tinyint类型可以存储2的8次⽅,也就是256种可能性,从0开始计数,⽆符号也就是可以 存储0~255,如果是有符号,那就是-128~127。
2)smallint:存储所占两个字节,同上也就是可以存储2的16次⽅,也就是可以存储65536种可能性,⽆符号从0开始则是可以存储
varchar2最大长度
0~65535,有符号则是-32768~32767。
3)mediumint:存储所占三个字节,也就是2的24次⽅,可以存储16777216种可能性,⽆符号可以存储0~16777215,有符号可以存储-8388608~8388607。
4)int:存储所占四个字节,也就是2的32次⽅,可以存储4294967296种可能性,⽆符号可以存储0~4294967295,有符号则是-2147483648~2147483647。
5)bigint:存储所占8个字节,也就是2的64次⽅,可以存储2的64次种可能性,⽆符号可以存储0~((2³²×²)-1),有符号则是-(2³²×²)/2 ~ (2³²×²)/2-1。
我们经常会见到int(11)、tinyint(1)这种后⾯跟括号⾥⾯放数字的情况,很多⼈以为这是代表的该类型可存储的长度,但是我们上⾯已经分析了存储的情况,这种理解肯定是不对的,实际上括号⾥的数字表⽰的是最⼤显⽰宽度,这个数字和存储⼤⼩及其类型没有任何关系,也就是说tinyint(1)和tinyint(3)都是存储⼀个字节,并不会因为括号⾥的数字改变,这个数字仅仅是显⽰最⼤宽度。
例如tinyint(3)存储11则会显⽰011,因为最⼤宽度为3,达不到的情况下⽤0来补充,这样的话就很好理解了,下图也是做了⼀定的对⽐,分别存储的是1和123456、1234567890这⼏个数字。
在设置这个括号⾥的数值时我们也要⼩⼼,因为mysql⼿册上明确写了:当 mysql 为某些复杂的联结(join)⽣成临时表时,你可能会遇到问题,因为在这种情况下,mysql 信任地认为所有的值均适合原始的列宽度!