AMH mysql占用cpu过高,分享BigDecimal的用法与MySQL算术运算符

如果对数值结果精度要求很高,那么就可以使用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;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值