如果对数值结果精度要求很高,那么就可以使用BigDecimal,BigDecimal可以精准的控制小数点后面的数字
Java培训
实例 BigDecimal 对象
通常会使用 String 和 int 构造方法实例出 BigDecimal 对象,即
new BigDecimal(String val);
new BigDecimal(int val);
如参数为 double 类型,得先转换成 String 类型再入参
new BigDecimal(Double.toString(123.123));
BigDecimal 加减乘除
加减乘除都是用 BigDecimal 对象点(.)加减乘除方法入参 BigDecimal 对象,返回的也是 BigDecimal 对象
加:BigDecimal add = new BigDecimal(“123.123”).add(new BigDecimal(“123.123”)); —> 246.246
减:BigDecimal subtract = new BigDecimal(“123.123”).subtract(new BigDecimal(“123.123”)); —> 0.000
乘:BigDecimal multiply = new BigDecimal(“123.123”).multiply(new BigDecimal(“123.123”)); —> 15159.273129
除:BigDecimal divide = new BigDecimal(“123.123”).divide(new BigDecimal(“123.123”)); —> 1
注:其中除法一般不会这样直接除,在不能整除的情况下,这样运行程序是会报错的,所以一般除法会使用下面这个重载方法
正常计算 10/40 结果为 0.25, 在这里是计算 十除以四十,保留一位小数,四舍五入模式。所以得到的结果为 0.3
最常用的模式:
① ROUND_HALF_UP:四舍五入
② ROUND_HALF_DOWN:向下取舍(去掉保留小数位后面的小数)
Scale 属性操作
① 获取小数的位数:new BigDecimal(“123.123”).scale() —> 3
② setScale() 方法保留几位小数
setScale(int NewScale):(注:入参的数字只能大于等于小数的位数,括号中只能入参大于等于 3 的数)
例: new BigDecimal(“123.123”).http://www.xingkongmj.com/news/id/78.htmlsetScale(3) —> 123.123
new BigDecimal(“123.123”).setScale(5) —> 123.12300
setScale(int newScale, RoundingMode roundingMode):
例:new BigDecimal(“123.123”).setScale(2,RoundingMode.HALF_UP) —> 123.12
new BigDecimal(“123.125”).setScale(2,RoundingMode.HALF_UP) —> 123.13
new BigDecimal(“123.123”).setScale(2,RoundingMode.HALF_DOWN) —> 123.12
new BigDecimal(“123.125”).setScale(2,RoundingMode.HALF_DOWN) —> 123.12
compareTo 比较大小
等于:new BigDecimal(“123.123”).compareTo(new BigDecimal(“123.123”))==0 —> true
new BigDecimal(“123.123”).compareTo(new BigDecimal(“123.123”)) —> 0
如果 compareTo 的结果为 0 的话,就证明两个对象相等(当左边不等于右边时,第一个表达式则为 false)
小于:new BigDecimal(“123.122”).compareTo(new BigDecimal(“123.123”)) < 0 —> true
new BigDecimal(“123.122”).compareTo(new BigDecimal(“123.123”)) —> -1
如果 compareTo 的结果为 -1 的话,就证明左边小于右边(当左边大于等于右边时,第一个表达式则为 false)
大于:new BigDecimal(“123.124”).compareTo(new BigDecimal(“123.123”)) > 0 —> true
new BigDecimal(“123.124”).http://www.xingkongmj.com/news/id/77.htmlcompareTo(new BigDecimal(“123.123”)) —> 1
如果 compareTo 的结果为 1 的话,就证明左边大于右边(当左边小于等于右边时,第一个表达式则为 false)
(1)算术运算符:+ – * /(除也可以写成div) %(取模可以写成mod)
(2)比较运算符:= > >= < <= !=(不等于还可以写成<>) <=>(安全等于)
(3)逻辑运算符:&&(逻辑与也可以写成and) ||(逻辑或也可以写成or) not(逻辑非)
(4)范围:表达式 between … and … (也可以写成 表达式>=… and 表达式 <=…)
表达式 not between … and …(也可以写成 表达式…)
(5)集合:in (值,值,值…) not in(值,值,值…)
(6)模糊查询:LIKE NOT LIKE,通配符:%表示0-n个字符,_下划线代表一个字符
(7)位运算符:&(按位与) |(按位或)^(按位异或)~(按位取反)>>(右移)<
(8)NULL值判断,is null 或http://www.xingkongmj.com/news/id/76.html is not ull,如果使用null=null,null<>null,null=0,null<>0,null=false等都不对
不过xxx is null 可以使用xxx <=> null ,xxx is not null 可以写成 not xxx <=> null
结论:所有的运算符遇到NULL结果都是NULL,除了<=>
1、算术运算符
#一、算术运算符
#+,-,*,/(div),%(mod)
#筛选出eid是偶数的员工
SELECT * http://www.xingkongmj.com/news/id/75.htmlFROM t_employee WHERE eid % 2 = 0;
SELECT * FROM t_employee WHERE eid MOD 2 = 0;
#查看每天的基本工资值,每个月按22天算
SELECT eid,basic_salary/12 AS “日薪”
FROM t_salary;
#div也表示除,但是只保留整数部分
FROM t_salary;
#关于+,在Java中,+的左右两边如果有字符串,那么表示字符串的拼接,但是在MySQL中+只表示数值相加,
#如果遇到非数值类型,先尝试转成数值,如果转失败,就按0计算
SELECT eid+ename FROM t_employee;
SELECT eid+birthday FROM t_employee;
SELECT CONCAT(eid,”:”,ename) AS result FROM t_employee;
文章来源: blog.csdn.net,作者:清风可依旧,版权归原作者所有,如需转载,请联系作者。
原文链接:blog.csdn.net/weixin_52276913/article/details/110293558