设为首页 收藏本站
查看: 396|回复: 0

[经验分享] 【转】Oracle查询保留两位小数

[复制链接]

尚未签到

发表于 2016-8-12 06:36:17 | 显示全部楼层 |阅读模式
  原文
  
  TO_CHAR(字段名,'999,999,999.99')
  
  使用TO_CHAR的方式,有两个弊端,也是需要注意的地方:
  
  1>整数部分的9要写的足够多,否则会错误显示,如下:
  
  错误:SELECT TO_CHAR(199999999.1256,'9,999.99') FROM DUAL              --显示结果:#########
正确:SELECT TO_CHAR(199999999.1256,'999,999,999.99') FROM DUAL   --显示结果:199,999,999.13
  
  2>对0这种情况要单独处理,当为0时,会显示为.00,而非0.00。如下:
  
  错误:SELECT TO_CHAR(0,'9,99.99') FROM DUAL        --显示结果:.00
正确:SELECT DECODE(0,0,'0.00',TO_CHAR(199999999.1256,'999,999,999.99')) FROM DUAL    --显示结果:0.00
  
  
  
  以下为保留小数处理的相关函数:
  
  一、ROUND(四舍五入):ROUND( number, [ decimal_places ] )
  
  描述 : 传回一个数值,该数值是按照指定的小数位元数进行四舍五入运算的结果。
SELECT ROUND( number, [ decimal_places ] ) FROM DUAL
参数:
number : 欲处理之数值
decimal_places : 四舍五入 , 小数取几位 ( 预设为 0 )
示例 :
select round(123.456, 0) from dual;          回传 123
select round(123.456, 1) from dual;          回传 123.5
select round(123.456, 2) from dual;          回传 123.46
select round(123.456, 3) from dual;          回传 123.456
select round(-123.456, 2) from dual;         回传 -123.46
  
  当然,保留两位小数的处理,在格式要求的不是很严格的条件下,也可以用round函数。
  
  在保留小数这个问题上round函数有以下弊端:
  
  ①当为整数时,无论如何写,最终返回的都是整数,如下:
  
  SELECT ROUND(199.000,2) FROM DUAL --199
  
  ②返回值中不会自带千分符,如下:
  
  SELECT ROUND(199999.2356,2) FROM DUAL  --199999.24
  
  二、DECODE:DECODE(input_value,value,result[,value,result…][,default_result])
  
  描述:DECODE函数相当于一条件语句(IF).它将输入数值与函数中的参数列表相比较,根据输入值返回一个对应值。函数的参数列表是由若干数值及其对应结果值组成的若干序偶形式。当然,如果未能与任何一个实参序偶匹配成功,则函数也有默认的返回值。区别于SQL的其它函数,DECODE函数还能识别和操作空值.
DECODE(input_value,value,result[,value,result…][,default_result]);
参数:
input_value 试图处理的数值。
value  是一组成序偶的数值。如果输入数值与之匹配成功,则相应的结果将被返回。对应一个空的返回值,可用关键字NULL于之对应。
result  是一组成序偶的结果值。
default_result 未能与任何一序偶匹配成功时,函数返回的默认值。
示例:
SELECT checkup_type,
DECODE(blood_test_flag,’Y’,’Yes’,’N’,’No’,NULL,’None’,’Invalid’)
FROM checkup;

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-256478-1-1.html 上篇帖子: oracle中exp/imp使用格式 下篇帖子: oracle 复制表结构和表数据
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表