oracle保留两位⼩数解决⽅案
公司需要处理⼀些报表,需要使⽤百分率,保留2位⼩数,只⽤round和trunc函数都可以实现(round(_data,2) ),只是格式不是很⼯整,对格式要求不严谨的情况下使⽤round即可.
个⼈认为⽐较⽅便的⼀种
select decode(n_jg,0,'0.00',trim(to_char(n_jg,'9999999.99'))) from tbl
如果只是检索,可是使⽤:
1、select trunc(CUR_SUM,2) from data_record;
将⼩数转化成百分⽐=> round(zcbj/zs*100)||'%' ==trunc((zcbj/zs),2)*100||'%'
2、如果想更新数据,可以使⽤:
update data_record set CUR_SUM=trunc(CUR_SUM,2) where REC_NO=123
trunc函数怎么保留小数
to_char(round(data.amount,2),'FM9999999999999999.00') as amount
不⾜之处是,如果数值是0的话,会显⽰为.00⽽不是0.00。
另⼀需要注意的是,格式中⼩数点左边9的个数要够多,否则查询的数字会显⽰为n个符号“#”。
解决⽅式如下:
select decode(salary,0,'0.00',(to_char(round(salary,2),'fm99999999999999.00'))) from can_do;
case
when instr(to_char(data.amount), '.') < 1 then
data.amount || '.00'
when instr(to_char(data.amount), '.') + 1 = length(data.amount) then
data.amount || '0'
else
to_char(round(data.amount, 2))
end as amount_format
column amount format l9999999999.99
此⽅法的不⾜是,format中的⼩数点左⾯的9的个数要已知,否则会出现超过的数字显⽰为>###的情况。
另外⼀个问题是,使⽤column时,设置⽣效是session级还是system级,需要注意。
也许某张表的数值列不总是要求所有的地⽅显⽰时,都是⼩数点后两位的格式,此时只能使⽤session级,但是有个数据库连接会话超时的问题,如果不是使⽤到system级,不建议使⽤该⽅法。
select trim(to_char(1234,'99999999999999.99')) from dual;
select ltrim(trim(to_char(1234.525,'00000000000000.00')),'0') from dual;
此处使⽤了14个9或者14个0的格式,建议使⽤14个9的⽅式,⽅便些。⽅法四的不⾜之处是:
如果数值是0的话,转化之后为.00⽽不是0.00,补救措施是,decode⼀下。
另⼀需要注意的是,格式中⼩数点左边9或者0的个数要够多,负责查询的数字会显⽰为n个符号“#”。
如下:
select decode(salary,0,'0.00',trim(to_char(salary,'99999999999999.99'))) from can_do;
select decode(salary,0,'0.00',ltrim(trim(to_char(salary,'00000000000000.00')),'0')) from can_do;
:建议使⽤⽅法四中的trim+to_char的⽅式或者⽅法⼀的补救之后的⽅式,⽽且最好使⽤⼩数点左边n个9的⽅式,不要使⽤0的⽅式,否则,要多⼀步trim处理。
即:select decode(salary,0,'0.00',trim(to_char(salary,'99999999999999.99'))) from can_do;
select decode(salary,0,'0.00',(to_char(round(salary,2),'fm99999999999999.00'))) from can_do;

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。

发表评论