亲宝软件园·资讯

展开

MySQL 数据类型

昨天的风​​​​​​​ 人气:0

数据类型

日常开发中,最常使用到的 MySQL 中常用的数据类型有 : 整型, 浮点型, 定点数, 字符型, 时间日期类型. 下面对其分别进行总结。

整型

格式为 : INT[(M)] [UNSIGNED] [ZEROFILL]

浮点型

定点数

浮点型在数据库中存放的是近似值, 而定点类型在数据库中存放的是精确值. 所以对于金额等精度要求高的数据, 使用定点数 decimal 来保存.

decimal(m,d) 参数 m 是总个数, d 是小数位.  ( m<65, d<30, d<m )

字符型

字符型含义占用字节数
char(n)固定长度, 最多 255 个字符4 byte
varchar(n)可变长度, 最多 65535 个字符实际存入字节数+1

日期时间型

日期时间类型占用空间(字节数)日期格式
DATETIME8 byteYYYY-MM-DD HH:MM:SS
TIMESTAMP4 byteYYYY-MM-DD HH:MM:SS
DATE4 byteYYYY-MM-DD
TIME3 byteHH:MM:SS
YEAR1 byteYYYY
CREATE TABLE USER(
  ...
  create_time timestamp NULL default CURRENT_TIMESTAMP,    -- 默认为当前时间
  ...
)

字段类型的选取原则

原因:整型运算快, 且节省空间. char, varchar 要考虑字符集的转换与排序时的校对集, 所以速度慢.

原因 : 小空间的类型占用的磁盘, 内存, CPU 缓存, CPU 处理时间都更少.

比如 : 应该使用整型来存储 IP 地址, 而不是字符型. 应该使用日期时间类型来存储日期时间, 而不是字符型.

如果列中的数据长度差不多一致, 比如 : SFZ号, 学号等, 则应该考虑使用 char 类型.

对于那些长度未知的字符串, 使用 varchar.

如果列中的最大数据长度小于 50 Byte (15个字符左右), 则一般考虑使用 char.

精确数据只能使用 decimal 类型.

非精确数据优先使用 float 类型, ( float 比 decimal 的存储空间小 )

比如记录移动设备平台, 只有两个值:android, ios, 那么就可以使用 0 表示 android, 1 表示 ios, 并写好注释.

以上原则主要是从以下角度考虑 :

而变长数据则还需要多一步去查询下一个数据的偏移量. 不过定长数据可能会浪费更多的存储空间.

字符串的比较与当前的排序规则有关, 它需要去查询当前排序规则的字典顺序, 而数字不需要.

加载全部内容

相关教程
猜你喜欢
用户评论