mysql数据库字段类型的选择原则

原文链接:http://blog.csdn.net/u013412790/article/details/51615407

数据库类型的选择对数据库的性能影响很大 
1 . 数据类型会影响存储空间的开销

2 . 数据类型会影响数据查询性能

所以当一个数据类型可以有多种选择多种类型的时候,应该优先考虑数字类型,其次是日期或二进制类型,最后应该是字符类型。对于相同级别的数据类型,应该优先选择占用空间小的数据类型。 
原理:在对数据进行比较(查询条件,JOIN条件及排序)操作时:同样的数据,字符处理往往比数字处理慢,而且在数据库中,数据的处理是以页为单位,列的长度越小,数据类型占用的空间越小,利于性能的提升。

下面是字段类型所占的字节大小

这里写图片描述

Tinyint,SmallInt,Mediumint,Int,Bingint该如何选择

1 .从 0 到 255 的整型数据。存储大小为 1 字节。适合使用Tinyint

2.从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。适合使用smallint

3.从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。int 的 SQL-92 同义字为 integer。适合使用int

4.从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。存储大小为 8 个字节。适合使用bigint

char与varchar如何选择

1.如果列中要存储的数据的长度差不多是一致的,则应该考虑char,否则应该考虑用varchar.

2.如果列中最大数据的长度小于50Byte,则一般也考虑使用char(当然,如果这个列很少用,则基于节省空加你和减少I/O的考虑,还是可以使用varchar)

3.一般不宜定义大雨50Byte的char类型列。 
注意:utf8每一个字符时3Byte

decimal和float如何选择

1.decimal用于存储精确数据,而float只能用于存储非精确数据,故精确数据最好使用decimal类型

2.由于float的存储空间的开销一般比decimal小(精确到7为小数只需要4个字节,而精确到15位小数只需要8个字节)故非精确数据类型建议使用float

时间类型如何存储

1.使用int来存储时间字段的优缺点 
优点:字段的长度比datetime小 
缺点:使用不方便,需要函数进行转换 
限制:只能存储到2038-1-19 11:14:07 即2^32为2147483648

2,需要考虑需要存储时间的粒度 
年 月 日 小时 分钟 秒 周

posted on 2017-04-26 17:01  BuildyMan  阅读(4290)  评论(1编辑  收藏  举报

导航