zoukankan      html  css  js  c++  java
  • mysql

    分类:

    浮点数定点数来表示小数

    1. 浮点类型有两种,分别是单精度浮点数(FLOAT)和双精度浮点数(DOUBLE
    2. 定点类型只有一种,就是 DECIMAL

    显示宽度 与 小数位数

    浮点类型和定点类型都可以用(M, D)来表示,其中M称为精度,表示总共的位数D称为标度,表示小数的位数

    浮点数类型的取值范围为 M(1~255)和 D(1~30,且不能大于 M-2),分别表示显示宽度和小数位数。M 和 D 在 FLOAT 和DOUBLE 中是可选的,FLOAT 和 DOUBLE 类型将被保存为硬件所支持的最大精度。DECIMAL 的默认 D 值为 0、M 值为 10。

    MySQL 中的小数类型和存储需求:



    类型名称说明存储需求
    FLOAT 单精度浮点数 4 个字节
    DOUBLE 双精度浮点数 8 个字节
    DECIMAL (M, D),DEC 压缩的“严格”定点数 M+2 个字节

    取值范围:

    decimal:

    DECIMAL 的存储空间并不是固定的,而由精度值 M 决定,占用 M+2 个字节

    FLOAT 类型的取值范围如下:

    • 有符号的取值范围:-3.402823466E+38~-1.175494351E-38。
    • 无符号的取值范围:0 和 -1.175494351E-38~-3.402823466E+38。

    DOUBLE 类型的取值范围如下:

    • 有符号的取值范围:-1.7976931348623157E+308~-2.2250738585072014E-308。
    • 无符号的取值范围:0 和 -2.2250738585072014E-308~-1.7976931348623157E+308。

    提示:不论是定点还是浮点类型,如果用户指定的精度超出精度范围,则会四舍五入进行处理。

    默认精度:

    FLOAT 和 DOUBLE 在不指定精度时,默认会按照实际的精度(由计算机硬件和操作系统决定),DECIMAL 如果不指定精度,默认为(10,0)。

    定点数的物理存储形式:

    1. 在 MySQL 中,定点数以字符串形式存储,在对精度要求比较高的时候(如货币、科学数据),使用 DECIMAL 的类型比较好
    2. 另外两个浮点数进行减法和比较运算时也容易出问题,所以在使用浮点数时需要注意,并尽量避免做浮点数比较
  • 相关阅读:
    【案例】ORA-02298
    ORA-01578: ORACLE 数据块损坏 (文件号 10, 块号 57896)ORA-01110: 数据文件 10: '/data/oradata/prod35.dbf'
    mysql主从架构,IO、SQL线程运行为YES,从库没有同步数据
    MySQL5.7.21报错:[Err] 1055
    ORACLE数据库黑/白名单
    Mongodb日常管理
    hive Hbase sql
    hive DDL操作
    hive 分桶及抽样调查
    hive 排序
  • 原文地址:https://www.cnblogs.com/gengyufei/p/14283983.html
Copyright © 2011-2022 走看看