最近在设计个酒店一体化产品的数据表设计,其中涉及到一些字段选择不同的数据类型
基础概念:
1)、1个字符等于多少字节 (不同的字符所占的字节是不一样的),在ASCII码中,一个数字、一个字母 代表一个【字节】,一个汉字(gbk编码下)占2个字节 一个汉字(utf8编码下)占3个字节
2)、【MYSQL】在版本4.0及以下 : varchar(20) 指的是20个字节 即:只能存储6个汉字,一个汉字3个字节(UTF8编码下)
3)、【MYSQL】在版本5.0及以上 : varchar(20) 指的是20个字符 即:可以存储20个汉字或者20个数字 或者20个字母
1、char和varchar:
char 是固定长度的类型 varchar是一种可变长度的类型,即:它们的区别是: char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)在varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节)
2、tinyint、smallint、mediumint、int、bigint、bit
类型 | 字节 | 最小值(带符号/不带符号) | 最大值(带符号/不带符号) |
tinyint | 1 | -128 / 0 | 127 / 256 |
smallint | 2 | -32768 / 0 | 32767 / 65536 |
mediumint | 3 | -8388608 / 0 | 8388607 / 16777215 |
int | 4 | -2147483648 / 0 | 2147483647 / 4294967295 |
bigint | 8 | -9223372036854775808 | 9223372036854775807 |
bit型数据其数据有两种取值:0或1,长度为1位。在输入0以外的其他值时,系统均把它们存储为1。这种数据类型常作为逻辑变量使用,用来表示真、假或是、否等二值选择。
2-1 关于int(4) 和 int(11) 的 区别
mysql数据库中int(4)的意义
在char和varchar这些类型的字段中,如果设置varchar(4),那么最大只能保存4个字符。因此许多人包括本人也一直以为int类型能存储的整数长度也和int字段的长度有关。
但是今天经过测试,发现int类型似乎并不是通常我们大多数人所认为的那样。
在没有为mysql 字段设置零填充 zerofill属性的时候,int(1)和int(11)没有任何区别。
测试发现int(1)和int(11),可以存储的最大数值都是 2147483647 。21亿。
但是,有一个奇怪的事情,字段在设置zerofill属性后,可以存储的最大数值居然翻了一倍,变成4294967295。 42亿。
字段在设置zerofill属性后,int(4)显示0003,而int(11)显示00000000003 (int类型最长支持11位)
也就是说,int(4),这个4不是指的int整型的长度,而是指设置zerofill属性后自动在前头填充0的位数。
经过以上测试,也就是说,以后建表的时候,如果不需填充0的话,似乎可以不用再为int字段设置长度了。
3、enum的使用
感谢以下作者的提供:
1、MySQL中varchar最大长度是多少?https://blog.csdn.net/qq_30336433/article/details/81669957