Oracle之保留两位⼩数
  项⽬需要使⽤百分率,保留2位⼩数,只⽤ round 和 trunc 函数都可以实现(round(_data,2) ),只是格式不是很⼯整,对格式要求不严谨的情况下使⽤ round 即可。
  以下是⽐较⽅便的⼀种:
select decode(n_jg,0,'0.00',trim(to_char(n_jg,'9999999.99'))) from table1
  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
  ⽅法⼀:使⽤to_char的fm格式
  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 then else end进⾏各种情况的判断处理
case
when instr(to_char(data.amount), '.') <1then
data.amount ||'.00'
when instr(to_char(data.amount), '.') +1= length(data.amount) then
data.amount ||'0'
else
to_char(round(data.amount, 2))
oracle中trunc函数用法end as amount_format
  ⽅法三:可以使⽤Oracle⾃带的参数设置
column amount format l9999999999.99
  此⽅法的不⾜是,format中的⼩数点左⾯的9的个数要已知,否则会出现超过的数字显⽰为>###的情况。
  另外需注意的是,使⽤column时,设置⽣效是session级还是system级。
  也许某张表的数值列不总是要求所有的地⽅显⽰时,都是⼩数点后两位的格式,此时只能使⽤session级,但是有个数据库连接会话超时的问题,如果不是使⽤到system级,不建议使⽤该⽅法。
  ⽅法四:使⽤to_char+trim的⽅式
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;

发表评论