oracle 保留两位小数

在Oracle数据库中,保留两位小数可以通过多种函数实现,主要包括ROUNDTRUNCTO_CHAR函数。每种函数都有其特定的使用场景和效果。

1. ROUND函数

ROUND函数用于对数值进行四舍五入操作,保留指定的小数位数。其基本语法为:

复制代码
ROUND(number, [decimal_places])
  • number:需要四舍五入的数值。
  • decimal_places:需要保留的小数位数,可选参数,默认为0。

示例

复制代码
SELECT ROUND(123.4567, 2) FROM DUAL; -- 结果为 123.46  
SELECT ROUND(123.45, 2) FROM DUAL;   -- 结果为 123.45  
SELECT ROUND(123, 2) FROM DUAL;      -- 结果为 123.00

注意:如果decimal_places为负数,则表示对整数部分进行四舍五入。

2. TRUNC函数

TRUNC函数用于截断数值到指定的小数位数,不进行四舍五入。其基本语法与ROUND函数类似:

复制代码
TRUNC(number, [decimal_places])

示例

复制代码
SELECT TRUNC(123.4567, 2) FROM DUAL; -- 结果为 123.45  
SELECT TRUNC(123.45, 2) FROM DUAL;   -- 结果为 123.45  
SELECT TRUNC(123, 2) FROM DUAL;      -- 结果为 123.00

3. TO_CHAR函数

TO_CHAR函数是一个格式化函数,可以将数值转换为字符串,并指定返回的格式。通过指定格式,可以实现保留两位小数的效果。其基本语法为:

复制代码
TO_CHAR(number, 'format_mask')
  • number:需要格式化的数值。
  • format_mask:格式化模式,其中FM用于去除尾随的空格,90作为占位符,9表示如果对应位置没有数字则不显示(即显示空格),0表示如果对应位置没有数字则显示0。

示例

复制代码
SELECT TO_CHAR(123.4567, 'FM999999990.00') FROM DUAL; -- 结果为 '123.46'  
SELECT TO_CHAR(123.45, 'FM999999990.00') FROM DUAL;   -- 结果为 '123.45'  
SELECT TO_CHAR(123, 'FM999999990.00') FROM DUAL;      -- 结果为 '123.00'

注意:在使用TO_CHAR函数时,如果格式模式中的小数位数大于原数值的小数位数,且小数位为0,则结果会用0来填充;如果小数位为9,则不填充(即显示空格,但FM会去除这些空格)。

总结

在Oracle中保留两位小数,可以根据实际需求选择ROUNDTRUNCTO_CHAR函数。ROUND函数适用于需要四舍五入的情况,TRUNC函数适用于需要直接截断的情况,而TO_CHAR函数则提供了更灵活的格式化选项。

相关推荐
爬山算法16 分钟前
Redis(168) 如何使用Redis实现会话管理?
java·数据库·redis
零日失眠者37 分钟前
【Oracle入门到删库跑路-17】实战案例:云环境部署实践
数据库·mysql·oracle
可爱の小公举1 小时前
Redis技术体系全面解析
数据库·redis·缓存
一 乐1 小时前
物业管理|基于SprinBoot+vue的智慧物业管理系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot
孟意昶1 小时前
Doris专题27-mysql兼容性与join连接
大数据·数据库·分布式·sql·mysql·doris
whn19772 小时前
Gbase 8A密码有效期剩余天数检查
数据库
煎蛋学姐2 小时前
SSM速到校园网上订餐网站5n2pv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·用户管理·校园订餐系统·ssm 框架
西岭千秋雪_2 小时前
MySQL日志梳理(存储引擎层)
java·数据库·分布式·mysql·oracle
老华带你飞2 小时前
英语学习|基于Java英语学习系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·学习
思成不止于此2 小时前
MySQL 查询基础(一):列选择、算数运算与别名使用
数据库·笔记·sql·学习·oracle