MySQL入门笔记

参考书籍《MySQL入门很简单》

    数据类型是数据的一种属性,可以决定数据的存储方式、有效范围和相应的限制。

1.整数类型

  1.1 MySQL的整数类型

      MySQL中int类型和integer类型是一样的。

  1.2 指定类型的显示宽度

      数据类型(显示宽度)

      默认显示宽度:

               

       一个数据类型的默认显示宽度刚好能显示该数据类型的所有值。默认显示宽度其实也是最大宽度。

       如果设置的宽度小于默认宽度,依然可以插入大于显示宽度但是不超过默认宽度的值。这时候设置的宽度在显示该记录时失效。但是不能插入超过默认宽度的数值。

  1.3 zerofill参数

      参数不足的显示空间由0来填补。在使用该参数的时候,会自动加上unsigned属性,即该整数类型只能表示无符号数,且显示宽度比默认宽度小1.

  1.4 auto_increment属性

      自增字段,在插入新的记录时,该字段的值都会在前一条记录的基础上加1.

2.浮点数类型和定点数类型

  2.1 float, double, cecimal 

       MySQL使用浮点数和定点数表示小数。浮点数包括单精度浮点数(float)和双精度浮点数(double)。定点数类型就是decimal型。

      

      decimal型的取值范围与double相同。decimal的有效取值范围由M和D决定,并且decimal的字节数是M+2,也就是说定点数的存储空间是根据其精度决定的。

  2.2 指定精度

       数据类型(M, D)

       M:精度,是数据的总长度,小数点不占位数;D:标度,指小数点后的长度。

      以上指定小数精度的方法对于浮点数和定点数都是适用的,但是,不是浮点数的标准方法,在定义浮点数的时候尽量不要使用,否则会影响数据库迁移。

  2.3 精度控制

      插入值的精度高于实际定义的精度,系统会自动四舍五入,使值的精度达到要求。区别在于:

  • float和double型在四舍五入的时候不会报错,而decimal型会有警告;
  • float和double型默认保存实际精度,这与操作系统和硬件的精度有关;
  • decimal型默认整数位为10,小数位为0,即默认整数;
  • MySQL中定点数以字符串形式存储,精度比浮点数要高;
  • 浮点数会出现误差(浮点数一直存有的缺陷),如果对数据精确度要求比较高,选择定点数。
原文地址:https://www.cnblogs.com/dennis-liucd/p/6956745.html