ORACLE 中 TRUNC函数的使用

对date使用
TRUNC函数为指定元素而截去的日期值。
语法为:

TRUNC(date[,fmt])
1
例子:

trunc(sysdate,'yyyy') --返回当年第一天
trunc(sysdate,'mm') --返回当月第一天
trunc(sysdate,'d') --返回当前星期的第一天
trunc(sysdate,'dd')--返回当前年月日

 

对number使用
与round()函数类似,只不过不进行四舍五入,而是直接截取。
语法:

TRUNC(number[,decimals])
1
例子:

trunc(89.985,2)=89.98 -- 截去 小数点右边n位之后的数据
trunc(89.985)=89 -- 默认截去 小数点右边
trunc(89.985,-1)=80 -- 负数表示,截去小数点左边n位之前的数据

–Oracle trunc()函数的用法
/日期******/
1.select trunc(sysdate) from dual --2011-3-18 今天的日期为2011-3-18
2.select trunc(sysdate, ‘mm’) from dual --2011-3-1 返回当月第一天.
3.select trunc(sysdate,‘yy’) from dual --2011-1-1 返回当年第一天
4.select trunc(sysdate,‘dd’) from dual --2011-3-18 返回当前年月日
5.select trunc(sysdate,‘yyyy’) from dual --2011-1-1 返回当年第一天
6.select trunc(sysdate,‘d’) from dual --2011-3-13 (星期天)返回当前星期的第一天
7.select trunc(sysdate, ‘hh’) from dual --2011-3-18 14:00:00 当前时间为14:41
8.select trunc(sysdate, ‘mi’) from dual --2011-3-18 14:41:00 TRUNC()函数没有秒的精确

9.select trunc(123.458) from dual --123
10.select trunc(123.458,0) from dual --123
11.select trunc(123.458,1) from dual --123.4
12.select trunc(123.458,-1) from dual --120
13.select trunc(123.458,-4) from dual --0
14.select trunc(123.458,4) from dual --123.458
15.select trunc(123) from dual --123
16.select trunc(123,1) from dual --123
17.select trunc(123,-1) from dual --120

date常见用法
日期减一天
select trunc(sysdate-1) from dual;

减一秒
select trunc(sysdate-1/24/60/60) from dual;

number常见用法
select trunc(123.456) from dual; – 123 取整

————————————————
版权声明:本文为CSDN博主「chushiyunen」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/enthan809882/article/details/106194137/

posted @   Simon_Tan  阅读(765)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示