必威体育Betway必威体育官网
当前位置:首页 > IT技术

DECIMAL

时间:2019-08-18 16:12:09来源:IT技术作者:seo实验室小编阅读:83次「手机版」
 

decimal

一、简述

在实际的企业开发中,经常遇到需要存储金额(3888.00元)的字段,这时候就需要用到数据类型decimal。

mysql数据库中,DECIMAL的使用语法是:DECIMAL(M,D),其中,

M 的范围是1~65,

D 的范围是0~30,

而且D不能大于M

二、最大值

数据类型为DECIMAL的字段,可以存储的最大值/范围是多少?

例如:DECIMAL(5,2),则该字段可以存储-999.99~999.99,最大值为999.99。

也就是说D表示的是小数部分长度,(M-D)表示的是整数部分长度。

三、存储

DECIMAL类型的数据存储形式是,将每9位十进制数存储为4个字节(官方解释:Values for DECIMAL columns are stored using a binary format that packs nine decimal digits into 4 bytes)。

那有可能设置的位数不是9的倍数,官方还给了如下表格对照:

Leftover Digits

Number of Bytes

0

0

1–2

1

3–4

2

5–6

3

7–9

4

表格什么意思呢,举个例子:

1、字段DECIMAL(18,9),18-9=9,这样整数部分和小数部分都是9,那两边分别占用4个字节;

2、字段DECIMAL(20,6),20-6=14,其中小数部分为6,就对应上表中的3个字节,而整数部分为14,14-9=5,就是4个字节再加上表中的3个字节。

四、参考

https://dev.mysql.com/doc/refman/8.0/en/precision-math-decimal-characteristics.html

Copyright © 2018 Ansel. All rights reserved.

相关阅读

Mysql中的Decimal类型是什么?

 我们在Mysql中存字段的时候,比如,一些与金钱有关的数据。这个时候就会对精确到的要求非常高。那么这个时候,就会发现我们之前所学

BigDecimal中divide方法注意问题

BigDecimal中pide方法抛异常:Non-terminating decimal expansion; no exact representable decimal result 在使用 BigDecimal

BigDecimal加减乘除计算

前阵子做题遇到了大数的精确计算,再次认识了bigdecimal关于Bigdecimal意外的有许多小知识点和坑,这里特此整理一下为方便以后学习,希

关于Java中DecimalFormat()方法的调用

关于Java中DecimalFormat()方法的调用 我们可以从各种地方知道DecimalFormat类的使用方法,它的作用是格式化数字。 在此不多赘述,

常见对象_BigDecimal的加减乘除法的使用

package cn.itcast_02;import java.math.BigDecimal;/** 构造方法:*         public BigDecimal(String val):** 金融相关

分享到:

栏目导航

推荐阅读

热门阅读