oracle中的Round和Trunc:
2014-02-25 13:42
441 查看
一,对数字的操作
sql>select trunc(5.75), trunc(5.75,1), trunc(5.75,-1) from dual
trunc(x [,y]),其中如果没有指定y,则对x在0位小数进行截断
Eg:TRUNC(5.75)=5,如果y是负数,则对x在小数点左边的第|y|位处进行截断
TRUNC(5.75, -1)=0,这里应对小数点左边的第|-1|位截取,为什么是0,不是5?
另外ROUND函数是对数值进行取整.
Eg:Round(5.75)=6,表示对5.75在0位小数处进行取整四舍五入了?
Round(5.75, 1)=5.8,这里第1位小数是5?取整进行了四舍五入?
ROUND(5.75, -1)=10,对5.75在左边第|-1|位取整,左边第一位就是十位?5是个位,是第0位?
解答如下:
第一个问题 如果y是负数,则对x在小数点左边的第|y|位处进行截断,例如:TRUNC(5.75, -1)=0 5.75 看成 0005.75.000 从小数点左边第一位往左边截,不是0吗
第二个问题,例如:ROUND(5.75)=6,表示对5.75在0位小数处进行取整,这里0位小数是7? 0位小数是没有,不是7, 7是第一位小数了。5.75取整 就是6啊,是四舍五入了啊,要不 round和trunc就没区别了嘛。
ROUND(5.75, 1)=5.8,这里第1位小数是5? 不是,第一位小数是7 四舍五入就是 5.8
ROUND(5.75, -1)=10,对5.75在左边第|-1|位取整,左边第一位就是十位?小数点左边第一位是个位,你同样看成 00005.75000,从个位的左边开始取,并四舍五入。 个位是5 左边的十位是0,由于5是进1的,所以是10.
记起来有点困难哟!
上面的问题引自:http://www.examw.com/oracle/zhonghe/118269/
二、对日期
一、Oracle中的Round和Trunc:
如同对数字进行四舍五入和按位截取一样,Oracle对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途:
ROUND(date [, format])
TRUNC(date [, format])
Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分。
二、Round和Trunc函数示例:
SQL > select to_char(sysdate,
' yyyy-mm-dd hh24:mi:ss '
) now_date,
2 to_char(
Round
(sysdate), ' yyyy-mm-dd hh24:mi:ss
' ) round_date,
3 to_char(Trunc(sysdate),
' yyyy-mm-dd hh24:mi:ss '
) trunc_date
4
from dual;
NOW_DATE ROUND_DATE TRUNC_DATE
-- ------------------------------------ -------------------------------------- ----------------------
2008
- 06
- 30
14 :
52 : 13
2008 -
07
- 01
00 :
00 : 00
2008 -
06
- 30
00 :
00 : 00
这是一个典型的例子,由于我们没有指定round和trunc函数的格式,所以Oracle默认采用了按日期时间的格式,该例子中当前的时间是下午
14:52分,已经超过了12:00 AM这个中界线,所以Round返回07-01日而非06-30日。而Trunc不管三七二十一直接截取前面日期部分返回。
另外一个值得注意的地方是这两个函数返回的时分秒都是00:00:00,即一天的开始时间(对于12小时制的返回的是12:00:00 AM)。
三、指定格式的Round和Trunc函数示例:
如果我们对Round函数和Trunc函数指定了格式,事情就变得有点复杂了,不过核心思想还是不变:Round是四舍五入,Trunc是截取。举个例子来说,假如我们以年为格式,则现在Oracle的判断是基于年来判断,超过一年的一半(即6月30日),Round函数则返回下一年了,Trunc函数依然返回当前年。
SQL > select
sysdate "Now date",
2
Round
(sysdate, ' yyyy '
) Round_year,
3 Trunc(sysdate,
' yyyy ' ) Trunc_year
4
from dual;
Now date ROUND_YEAR TRUNC_YEAR
-- -------- ---------- ----------
30
- 6月 -
08 01 -
1月 - 08
01 - 1月
- 08
关于这两个函数可用的格式非常多,但日常应用中用得比较多的基本上就这几个,以Round函数为例:
select Round
(sysdate, ' Q '
) Rnd_Q,
Round
(sysdate, ' Month '
) Rnd_Month,
Round
(sysdate, ' WW '
) Rnd_Week,
Round
(sysdate, ' W '
) Rnd_Week_again,
Round
(sysdate, ' DDD '
) Rnd_day,
Round
(sysdate, ' DD '
) Rnd_day_again,
Round
(sysdate, ' DAY '
) Rnd_day_of_week,
Round
(sysdate, ' D '
) Rnd_day_of_week_again,
Round
(sysdate, ' HH12 '
) Rnd_hour_12,
Round
(sysdate, ' HH24 '
) Rnd_hour_24,
Round
(sysdate, ' MI '
) Rnd_minute
from dual
四、用trunc函数处理日期
日期用例 '2008-11-28 12:59:59'周五
1.没有fmt部分时
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:00:01','YYYY-MM-DD hh24:mi:ss')) FROM DUAL;
结果:
2008-11-28
2.得到最当前日期之前的最近的一个周日的日期
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D') FROM DUAL;
结果: 2008-11-23 周日
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D')+1 FROM DUAL;
结果: 2008-11-24 周一
3.得到最当前日期的所在月份的第一天
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM') FROM DUAL;
结果: 2008-11-1
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM')-1 FROM DUAL;
结果:
2008-10-31
4.得到最当前日期的所在年份的第一天
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y') FROM DUAL;
结果: 2008-1-1
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y')-1 FROM DUAL;
结果:
2007-12-31
sql>select trunc(5.75), trunc(5.75,1), trunc(5.75,-1) from dual
trunc(x [,y]),其中如果没有指定y,则对x在0位小数进行截断
Eg:TRUNC(5.75)=5,如果y是负数,则对x在小数点左边的第|y|位处进行截断
TRUNC(5.75, -1)=0,这里应对小数点左边的第|-1|位截取,为什么是0,不是5?
另外ROUND函数是对数值进行取整.
Eg:Round(5.75)=6,表示对5.75在0位小数处进行取整四舍五入了?
Round(5.75, 1)=5.8,这里第1位小数是5?取整进行了四舍五入?
ROUND(5.75, -1)=10,对5.75在左边第|-1|位取整,左边第一位就是十位?5是个位,是第0位?
解答如下:
第一个问题 如果y是负数,则对x在小数点左边的第|y|位处进行截断,例如:TRUNC(5.75, -1)=0 5.75 看成 0005.75.000 从小数点左边第一位往左边截,不是0吗
第二个问题,例如:ROUND(5.75)=6,表示对5.75在0位小数处进行取整,这里0位小数是7? 0位小数是没有,不是7, 7是第一位小数了。5.75取整 就是6啊,是四舍五入了啊,要不 round和trunc就没区别了嘛。
ROUND(5.75, 1)=5.8,这里第1位小数是5? 不是,第一位小数是7 四舍五入就是 5.8
ROUND(5.75, -1)=10,对5.75在左边第|-1|位取整,左边第一位就是十位?小数点左边第一位是个位,你同样看成 00005.75000,从个位的左边开始取,并四舍五入。 个位是5 左边的十位是0,由于5是进1的,所以是10.
记起来有点困难哟!
上面的问题引自:http://www.examw.com/oracle/zhonghe/118269/
二、对日期
一、Oracle中的Round和Trunc:
如同对数字进行四舍五入和按位截取一样,Oracle对时间日期也提供了这两种功能。但比起对数字进行四舍五入和截取比较复杂:这是因为时间日期是有格式的。下面看看这两个函数的定义和用途:
ROUND(date [, format])
TRUNC(date [, format])
Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分。
二、Round和Trunc函数示例:
SQL > select to_char(sysdate,
' yyyy-mm-dd hh24:mi:ss '
) now_date,
2 to_char(
Round
(sysdate), ' yyyy-mm-dd hh24:mi:ss
' ) round_date,
3 to_char(Trunc(sysdate),
' yyyy-mm-dd hh24:mi:ss '
) trunc_date
4
from dual;
NOW_DATE ROUND_DATE TRUNC_DATE
-- ------------------------------------ -------------------------------------- ----------------------
2008
- 06
- 30
14 :
52 : 13
2008 -
07
- 01
00 :
00 : 00
2008 -
06
- 30
00 :
00 : 00
这是一个典型的例子,由于我们没有指定round和trunc函数的格式,所以Oracle默认采用了按日期时间的格式,该例子中当前的时间是下午
14:52分,已经超过了12:00 AM这个中界线,所以Round返回07-01日而非06-30日。而Trunc不管三七二十一直接截取前面日期部分返回。
另外一个值得注意的地方是这两个函数返回的时分秒都是00:00:00,即一天的开始时间(对于12小时制的返回的是12:00:00 AM)。
三、指定格式的Round和Trunc函数示例:
如果我们对Round函数和Trunc函数指定了格式,事情就变得有点复杂了,不过核心思想还是不变:Round是四舍五入,Trunc是截取。举个例子来说,假如我们以年为格式,则现在Oracle的判断是基于年来判断,超过一年的一半(即6月30日),Round函数则返回下一年了,Trunc函数依然返回当前年。
SQL > select
sysdate "Now date",
2
Round
(sysdate, ' yyyy '
) Round_year,
3 Trunc(sysdate,
' yyyy ' ) Trunc_year
4
from dual;
Now date ROUND_YEAR TRUNC_YEAR
-- -------- ---------- ----------
30
- 6月 -
08 01 -
1月 - 08
01 - 1月
- 08
关于这两个函数可用的格式非常多,但日常应用中用得比较多的基本上就这几个,以Round函数为例:
select Round
(sysdate, ' Q '
) Rnd_Q,
Round
(sysdate, ' Month '
) Rnd_Month,
Round
(sysdate, ' WW '
) Rnd_Week,
Round
(sysdate, ' W '
) Rnd_Week_again,
Round
(sysdate, ' DDD '
) Rnd_day,
Round
(sysdate, ' DD '
) Rnd_day_again,
Round
(sysdate, ' DAY '
) Rnd_day_of_week,
Round
(sysdate, ' D '
) Rnd_day_of_week_again,
Round
(sysdate, ' HH12 '
) Rnd_hour_12,
Round
(sysdate, ' HH24 '
) Rnd_hour_24,
Round
(sysdate, ' MI '
) Rnd_minute
from dual
四、用trunc函数处理日期
日期用例 '2008-11-28 12:59:59'周五
1.没有fmt部分时
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:00:01','YYYY-MM-DD hh24:mi:ss')) FROM DUAL;
结果:
2008-11-28
2.得到最当前日期之前的最近的一个周日的日期
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D') FROM DUAL;
结果: 2008-11-23 周日
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'D')+1 FROM DUAL;
结果: 2008-11-24 周一
3.得到最当前日期的所在月份的第一天
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM') FROM DUAL;
结果: 2008-11-1
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'MM')-1 FROM DUAL;
结果:
2008-10-31
4.得到最当前日期的所在年份的第一天
语句: SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y') FROM DUAL;
结果: 2008-1-1
语句:
SELECT TRUNC(TO_DATE('2008-11-28 12:59:59','YYYY-MM-DD hh24:mi:ss'),'Y')-1 FROM DUAL;
结果:
2007-12-31
相关文章推荐
- Centos 6.4系统安装oracle 11G RAC出现的错误总结
- Oracle中CONNECT BY
- 在Redhat Enterprise linux 5上 安装Oracle10g Release 2
- 微軟将从 .NET 4 以后的版本弃用 System.Data.OracleClient 以及Oracle 的各种连接方法
- 在red hat linux下安装oracle的相关问题
- Oracle判断字段是否有汉字
- oracle查询重复数据与删除重复记录方法
- Oracle数据库备份与还原命令
- Java: Passing Array to Oracle Stored Procedure
- MFC中使用otl,oci链接oracle数据库
- oracle表锁住 解锁办法
- ORACLE 中IN和EXISTS比较
- ORACLE的SIGN函数和DECODE函数
- Oracle database启动过程分析
- Oracle数据库学习 第一天
- Oracle练习:有关Oracle用户scott的sql练习
- Oracle中的System Triggers(DDL触发器)
- Oracle Merge 使用
- Oracle的lpad与rpad函数的使用
- oracle 完全备份——增量备份