MYSQL数据库 的 decimal 字段类型 和 Java 的BigDecimal

mysql中的decimal , 在java中的用BigDecimal表示的。

  • decimal

decimal(18,0) 18是定点精度,0是小数位数。

decimal(a,b) a指定指定小数点左边和右边可以存储的十进制数字的最大个数,最大精度38。

b指定小数点右边可以存储的十进制数字的最大个数。小数位数必须是从 0 到 a之间的值。默认小数位数是 0。

  • BigDecimal

Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大或者更小的数进行运算和处理。float和double只能用来做科学计算或者是工程计算,在商业计算中要用java.math.BigDecimal。BigDecimal所创建的是对象,我们不能使用传统的+、-、*、/等算术运算符直接对其对象进行数学运算,而必须调用其相对应的方法。方法中的参数也必须是BigDecimal的对象。构造器是类的特殊方法,专门用来创建对象,特别是带有参数的对象。

  • BigDecimal的四则运算
BigDecimal a = new BigDecimal("123");
BigDecimal b = new BigDecimal("456");

BigDecimal c = a.add(b);// 加
BigDecimal d = a.subtract(b);// 减
BigDecimal e = a.multiply(b);// 乘

// 除
// 参数2:指定精度,保留6位小数 ; 参数3: 选择舍入模式,此处为 四舍五入
BigDecimal f = a.divide(b, 6, BigDecimal.ROUND_HALF_UP);

// jdk 1.9中第三个参数 被RoundingMode取代
BigDecimal f = a.divide(b,RoundingMode.DOWN);//舍弃小数位
BigDecimal f = a.divide(b,2,RoundingMode.HALF_DOWN );//2位小数;舍入模式为大于0.5进1,否则舍弃。

注: BigDecimal的除法,需要指定计算答案的精度, 不然计算机不知道你的精度为多少,会抛异常的。
Exception in thread “main” java.lang.ArithmeticException

  • BigDecimal 的 signum() 方法 : 返回此 BigDecimal 的正负号。
//返回 1 表示值 为正值 ;  0 表示 为 0 ;  -1 表示 负数 。
BigDecimal a = new BigDecimal("123");
int b = a.signum(); // 结果是 1
  • BigDecimal 的 compareTo()方法 , 比较大小 ; (不能直接使用算数运算符 == ,>, < 比较)
// 结果 : 1 表示 大于; 0 表示 等于; -1 表示 小于 .
BigDecimal a = new BigDecimal(0.5);
BigDecimal b = new BigDecimal(0.2);
int c = a.compareTo(b); // 结果 C = 1
### 回答1: MySQL字段类型长度和Java类型有以下对应关系: 1. 字符串类型: - CHAR(n):Java类型为String,长度为n。 - VARCHAR(n):Java类型为String,长度为n。 - TEXT:Java类型为String。 2. 数值类型: - INT:Java类型为int。 - BIGINT:Java类型为long。 - DECIMAL(p, s):Java类型BigDecimal,其中p表示总位数,s表示小数位数。 3. 日期和时间类型: - DATE:Java类型java.sql.Date。 - TIME:Java类型java.sql.Time。 - DATETIME:Java类型java.sql.Timestamp。 4. 布尔类型: - BOOL、BOOLEAN:Java类型为boolean。 5. 二进制类型: - BLOB:Java类型为byte[]。 需要注意的是,Java的数据类型MySQL字段类型并不完全一致,因此在进行数据类型转换时需要注意类型匹配。在使用JDBC连接MySQL进行数据操作时,可以根据需要使用ResultSet的get方法和PreparedStatement的set方法来进行数据类型的转换。同时,在设计数据库表结构时也需要根据实际需求选择合适的MySQL字段类型,以确保数据的存储和查询效率,并防止数据溢出或损失。 ### 回答2: MySQL字段类型长度和Java类型对应如下: 1. 字符串类型(VARCHAR、CHAR): - VARCHAR(n) 对应 Java 的 String 类型,表示一个可变长度的字符串,最大长度为 n,例如:VARCHAR(50) 对应 Java 的 String。 - CHAR(n) 对应 Java 的 String 类型,表示一个固定长度的字符串,长度为 n,例如:CHAR(20) 对应 Java 的 String。 2. 数值类型(INT、BIGINT、FLOAT、DOUBLE、DECIMAL): - INT 对应 Java 的 int 类型。 - BIGINT 对应 Java 的 long 类型。 - FLOAT 对应 Java 的 float 类型。 - DOUBLE 对应 Java 的 double 类型。 - DECIMAL(precision, scale) 对应 JavaBigDecimal 类型,其中 precision 表示总长度,scale 表示小数点后的位数,例如:DECIMAL(10, 2) 对应 JavaBigDecimal。 3. 日期和时间类型(DATE、TIME、DATETIME、TIMESTAMP): - DATE 对应 Java 的 LocalDate 类型。 - TIME 对应 Java 的 LocalTime 类型。 - DATETIME 和 TIMESTAMP 都对应 Java 的 LocalDateTime 类型。 4. 布尔类型(BOOLEAN、BIT): - BOOLEAN 对应 Java 的 boolean 类型。 - BIT(n) 对应 Java 的 byte[] 类型。 5. 其他类型: - BLOB 对应 Java 的 byte[] 类型,用于存储二进制数据。 - TEXT 对应 Java 的 String 类型,用于存储大文本数据。 需要注意的是,MySQL字段类型长度和Java类型对应是一种常见的映射方式,但不是唯一的方式。在不同的数据库和编程语言中,可能会有一些差异或变化。此外,还可以使用数据库连接工具或框架进行字段类型Java类型的自动映射。 ### 回答3: MySQL字段类型的长度和Java类型对应关系如下: 1. 数值类型: - TINYINT:Java类型为byte,长度为1字节。 - SMALLINT:Java类型为short,长度为2字节。 - MEDIUMINT:Java类型为int,长度为3字节。 - INT:Java类型为int,长度为4字节。 - BIGINT:Java类型为long,长度为8字节。 - FLOAT:Java类型为float,长度为4字节。 - DOUBLE:Java类型为double,长度为8字节。 - DECIMALJava类型BigDecimal,长度可自定义。 2. 字符串类型: - CHAR:Java类型为String,长度可自定义,最大为255字节。 - VARCHAR:Java类型为String,长度可自定义,最大为65535字节。 - TEXT:Java类型为String,长度可自定义,最大为65535字节。 - BLOB:Java类型为byte[],长度可自定义,最大为65535字节。 3. 日期和时间类型: - DATE:Java类型java.sql.Date,长度为3字节。 - TIME:Java类型java.sql.Time,长度为3字节。 - DATETIME:Java类型java.sql.Timestamp,长度为8字节。 - TIMESTAMP:Java类型java.sql.Timestamp,长度为4字节。 - YEAR:Java类型java.util.Date,长度为1字节。 4. 其他类型: - BOOLEAN:Java类型为boolean,长度为1字节。 - ENUM:Java类型为String,长度可自定义。 需要注意的是,MySQL字段类型长度可能会受到存储引擎和字符编码的影响,所以实际长度可能有所不同。对于字符串类型,长度指的是字符数,而不是字节数。另外,为了更准确地处理日期和时间类型,建议使用对应的Java日期时间类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值