zoukankan      html  css  js  c++  java
  • 数值列类型的选择 MYSQL5类型进阶

    MySQL有整数和浮点数值的列类型,如表1所示。整数列类型可以有符号也可无符号。有一种特殊的属性允许整数列值自动生成,这对需要唯一序列或标识号的应用系统来说是非常有用的。

    类型

    说明

    TINYINT 非常小的整数
    SMALLINT 较小整数
    MEDIUMINT 中等大小整数
    INT 标准整数
    BIGINT 较大整数
    FLOAT 单精度浮点数
    DOUBLE 双精度浮点数
    DECIMAL 一个串的浮点数

    表1:数值列类型

    每种数值类型的名称和取值范围如表2所示。
    M : 指出最大的显示尺寸。最大的合法的显示尺寸是 255 。
    D : 适用于浮点类型并且指出跟随在十进制小数点后的数码的数量。最大可能的值是30,但是应该不大于M-2。
    方括号(“[”和“]”)指出可选的类型修饰符的部分。

    类型说明

    取值范围

    TINYINT[(M)] 有符号值:-128 到127(- 27 到27 - 1)
    无符号值:0到255(0 到28 - 1)
    SMALLINT[(M)] 有符号值:-32768 到32767(- 215 到215 - 1)
    无符号值:0到65535(0 到21 6 - 1)
    MEDIUMINT[(M)] 有符号值:-8388608 到8388607(- 22 3 到22 3 - 1 )
    无符号值:0到16777215(0 到22 4 - 1)
    INT[(M)] 有符号值:-2147683648 到2147683647(- 231 到231- 1)
    无符号值:0到4294967295(0 到232 - 1)
    BIGINT[(M)] 有符号值:-9223372036854775808 到9223373036854775807(- 263到263-1)

    无符号值:0到18446744073709551615(0到264 – 1)

    FLOAT[(M, D)] 最小非零值:±1.175494351E - 38
    DOUBLE[(M,D)] 最小非零值:±2.2250738585072014E - 308
    DECIMAL (M, D) 可变;其值的范围依赖于M 和D

    表2:数值列类型的取值范围

    各种类型值所需的存储量如表3所示。

    类型说明

    存储需求

    TINYINT[(M)] 1字节
    SMALLINT[(M)] 2字节
    MEDIUMINT[(M)] 3字节
    INT[(M)] 4字节
    BIGINT[(M)] 8字节
    FLOAT[(M, D)] 4字节
    DOUBLE[(M, D)] 8字节
    DECIMAL (M, D) M字节(MySQL < 3.23),M+2字节(MySQL > 3.23 )

    表3:数值列类型的存储需求

    MySQL提供了五种整型: TINYINT、SMALLINT、MEDIUMINT、INT和BIGINT。INT为INTEGER的缩写。这些类型在可表示的取值范围上是不同的。整数列可定义为UNSIGNED从而禁用负值;这使列的取值范围为0以上。各种类型的存储量需求也是不同的。取值范围较大的类型所需的存储量较大。

    MySQL 提供三种浮点类型: FLOAT、DOUBLE和DECIMAL。与整型不同,浮点类型不能是UNSIGNED的,其取值范围也与整型不同,这种不同不仅在于这些类型有最大值,而且还有最小非零值。最小值提供了相应类型精度的一种度量,这对于记录科学数据来说是非常重要的(当然,也有负的最大和最小值)。

    在选择了某种数值类型时,应该考虑所要表示的值的范围,只需选择能覆盖要取值的范围的最小类型即可。选择较大类型会对空间造成浪费,使表不必要地增大,处理起来没有选择较小类型那样有效。对于整型值,如果数据取值范围较小,如人员年龄或兄弟姐妹数,则TINYINT最合适。MEDIUMINT能够表示数百万的值并且可用于更多类型的值,但存储代价较大。BIGINT在全部整型中取值范围最大,而且需要的存储空间是表示范围次大的整型INT类型的两倍,因此只在确实需要时才用。对于浮点值,DOUBLE占用FLOAT的两倍空间。除非特别需要高精度或范围极大的值,一般应使用只用一半存储代价的FLOAT型来表示数据。

    在定义整型列时,可以指定可选的显示尺寸M。如果这样,M应该是一个1 到255的整数。它表示用来显示列中值的字符数。例如,MEDIUMINT(4)指定了一个具有4个字符显示宽度的MEDIUMINT列。如果定义了一个没有明确宽度的整数列,将会自动分配给它一个缺省的宽度。缺省值为每种类型的“最长”值的长度。如果某个特定值的可打印表示需要不止M个字符,则显示完全的值;不会将值截断以适合M个字符。

    对每种浮点类型,可指定一个最大的显示尺寸M 和小数位数D。M 的值应该取1 到255。D的值可为0 到3 0,但是不应大于M - 2(如果熟悉ODBC 术语,就会知道M 和D 对应于ODBC 概念的“精度”和“小数点位数”)。M和D对FLOAT和DOUBLE 都是可选的,但对于DECIMAL是必须的。在选项M 和D时,如果省略了它们,则使用缺省值。

  • 相关阅读:
    Hadoop之HDFS的热备份
    Hadoop之联邦HDFS
    Hadoop之HDFS如何保证高可用
    Hadoop之HDFS的读流程
    Hadoop之HDFS数据写流程和写失败的情况
    Hadoop之HDFS的block、packet、chunk
    Hadoop之HDFS的元数据冷备份(CheckPoint)
    当ZooKeeper作为Dubbo的注册中心的时候,是怎么工作的?
    Dubbo
    mysql磁盘满了如何恢复
  • 原文地址:https://www.cnblogs.com/wbcms/p/1376305.html
Copyright © 2011-2022 走看看