深入了解mysql的4种常用、重要的数据类型
为了实现这一目标,它需要我们在数据库系统的常用数据类型有充分的认识。
下面我们来看一下mysql的重要数据类型
1、数值类型可以划分为数值类型:整型,浮点十进制类型。
所谓的“十进制”是指decimal和numeric,他们是同一类型的。严格地说,它不是一个数字类型,因为他们实际上是作为字符串存储,每一个数字值(包括小数点)占一个字节的存储空间,所以这种类型的消耗大量的存储空间,但它的优点是它的价值不会失去做浮点数计算精度,它更适合一些计算精度要求高,如价格计算。浮动取决于不同精度的类型可以是float或double。它们的优点是小数的精度,float可以表示非常小的值,可以是最小的值约1.17e-38(0.000 … 0117,小数点后的37零),双重可以表达更小的数,最小的数可以约2.22e-308(0.000 … 0222,小数点以及后跟307个零)的小数。float和double分别为4字节和8字节的存储空间。
对于整型,在mysql中有很多不同类型的整数,在设计数据库表,我们可以有一个字节tinyint或8字节bigint等,所以我们应该把过多考虑哪个类型来使用,以获得最小的存储空间,而不会失去任何准确性值。
tinyint,smallint,mediumint,int和bigint 1字节,2字节,3字节,4字节和8字节。对于无符号整数,这些类型能表示的最大整数是分别255,65535,16777215,4294967295 18446744073709551615。如果我们需要保存用户的年龄,tinyint就够了;如果是自增的id,我们应该使用mediumint而不是int,int还 是太大了。很多数据表并不会达到mediumint的范围
2、日期时间输入的日期和时间类型比较简单
如date,time,datetime,timestamp和year。如果我们只需要关心的日期,但没有分秒我们应该使用date,而不是datetime,但datetime是其中最常用的,一切按实际需要设计
3、字符类型不要以为字符类型仅仅是char
char和varchar的区别是,char是固定长度。如果你定义一个字段char(10),那么无论多少字节的数据,这将需要10个字节的空间;对于18位的身份证号码,则应该使用char(18),
varchar是可变长度的,如果我们有一个字段的值有不同的长度,那么我们应该使用varchar 。
4、枚举和集合类型枚举(enum)类型
最多可以定义到65,535种不同的字符串从中做出选择。
这可能需要取决于有多少个值在枚举类型中的一个或两个字节。集合(set)类型,最多可以有64个不同的成员,你可以选择零个或多个成员,集合成员的数量决定。例如,在sqlserver中,你可以使用bit类型来表示性别(男/女),但mysql中,bit在不同版本数据库中取值有差异,而使用tintint有时浪费的,你可以用enum('男','女'),这样可以节约很大空间