`
hepu
  • 浏览: 55726 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

Oracle中的Round和Trunc:

阅读更多

一、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

分享到:
评论
3 楼 yuxiangtong 2010-12-07  
不错,谢谢分享!
2 楼 timingbob 2010-08-02  
    不错
[b][/b][i][/i][u][/u]
引用
1 楼 xserver 2010-06-22  
这个写得不错啊

相关推荐

    oracle中函数 trunc(),round(),ceil(),floor的使用详解

    1.round函数(四舍五入) 描述 : 传回一个数值,该数值是按照指定的小数位元数进行四舍五入运算的结果 参数: number : 欲处理之数值 decimal_places : 四舍五入 , 小数取几位 ( 预设为 0 ) select round(123.456, ...

    oracle trunc函数使用介绍

    ### Oracle TRUNC 函数详解 ...综上所述,`TRUNC`函数在Oracle数据库中提供了强大的日期和数值截断功能,适用于多种不同的应用场景。正确理解和使用`TRUNC`函数可以帮助我们更灵活地处理数据,提高工作效率。

    Oracle round()函数与trunc()函数区别介绍

    round(x[,y]) 【功能】返回四舍五入后的值 ... 返回: 5555.67 , 5600 , 5556 【相近】trunc(x[,y]) 返回截取后的值,用法同round(x[,y]),只是不四舍五入 trunc(x[,y]) 【功能】返回x按精度y截取后的值 【参数】x,y,数

    Oracle自我补充之trunc()函数的使用方法

    Oracle数据库中的TRUNC函数是一个非常实用的工具,用于处理日期和数字类型的数据。它有两种主要的用法,分别针对日期和数字。 对于日期,TRUNC函数的主要作用是将日期值截断到特定的时间元素,例如年、月、日、小时...

    oracle 数字函数

    取整函数(ceil 向上取整 floor 向下取整) 取幂 power 和 求平方根 sqrt 求余 返回固定小数位数 round:四舍五入 trunc:直接截断 返回值的符号 正数返回为1 负数为 1

    第14章Oracle中的函数与表达式.pptx

    虽然具体内容未给出,Oracle还提供了一系列数学函数,如`round()`(四舍五入)、`trunc()`(截断小数部分)、`mod()`(求模运算)等,用于数值运算。 14.3 Oracle中的日期函数: 日期函数包括`sysdate`(获取当前...

    sql server和oracle中常用函数的比较

    本文将深入探讨SQL Server和Oracle中常用函数的比较,旨在帮助开发者更好地理解和选择适合自己需求的函数。以下是对给定内容中提及的SQL Server与Oracle函数的详细对比: ### 数学函数 1. **绝对值函数** - **SQL...

    Oracle常用函数和使用方法

    本文将详细介绍Oracle中一些最常用的函数及其使用方法,这些函数包括`DECODE`、`ABS`、`CEIL`、`MOD`、`ROUND`、`TRUNC`、`CONCAT`、`LOWER`和`LPAD`。 #### 二、DECODE函数:条件判断与转换 **功能描述**:`...

    oracle日积月累

    Oracle提供了一系列内置函数,如字符串函数(SUBSTR, INSTR, LENGTH), 数学函数(ROUND, TRUNC, MOD), 日期函数(SYSDATE, ADD_MONTHS, NEXT_DAY)等,它们在处理数据时非常实用。 3. **SQL*Plus命令**: SQL*...

    ORACLE和SQL语法区别归纳

    - **Oracle**: 使用`ROUND`或`TRUNC`函数。 - **SQL Server**: 使用`CONVERT`函数结合特定的样式代码。 5. **转换为日期** - **Oracle**: 使用`TO_DATE`函数。 - **SQL Server**: 使用`CONVERT`函数。 6. **...

    oracle trunc()函数的使用方法

    Oracle数据库中的TRUNC()函数是一个非常实用的工具,主要用于日期和数字的截取操作。它在数据处理和分析中扮演着重要角色,特别是在报表生成、数据整理和计算时。下面我们将详细探讨TRUNC()函数在日期和数字方面的...

    postgresql 兼容 oracle 函数

    3. **数学和转换函数**:如ROUND、TRUNC、TO_CHAR、TO_DATE等,这些在数据转换和计算中十分常用。 4. **游标和PL/SQL兼容性**:尽管PostgreSQL原生支持PL/pgSQL,但orafce提供了更接近Oracle的PL/SQL语法,包括游标...

    oracle错误好帮助文档和oracle函数大全

    - **数学函数**:如ROUND、TRUNC用于数值的四舍五入和截断,POWER用于求幂。 - **日期/时间函数**:如SYSDATE获取当前系统日期,ADD_MONTHS用于增加或减少日期。 - **字符串函数**:如SUBSTR用于提取子串,INSTR...

    ORACLE常用函数功能演示

    3. 数值处理函数如ABS取绝对值,SIGN判断符号,CEIL和FLOOR获取最接近的整数,ROUND和TRUNC进行四舍五入和截断操作,而MOD则用于求余数。 接着是字符处理函数,这些函数用于字符串的处理和转换: 1. 大小写转换...

    Oracle中日期格式字段处理.docx

    8. 日期和时间的四舍五入:在 Oracle 中,可以使用 ROUND 函数将日期和时间四舍五入到最近的日期。例如,ROUND(SYSDATE, 'DAY') 将当前日期四舍五入到最近的星期天。 9. 日期和时间的差值计算:在 Oracle 中,可以...

    oracle sql 內置函數大全.ppt

    本资料“Oracle SQL 内置函數大全”详细介绍了这些函数的使用,包括数学函数、字符串函数、日期时间函数、转换函数、比较函数等,旨在帮助用户更有效地在Oracle数据库中进行数据查询和分析。 1. 数学函数: - ABS...

    oracle中文基本操作教程

    2. 数值函数:ROUND()用于四舍五入,TRUNC()用于截断小数部分,MOD()用于求余数。 3. 日期函数:SYSDATE返回当前系统日期,ADD_MONTHS()用于增加月份,EXTRACT()用于提取日期的特定部分,如年、月、日。 4. 条件...

Global site tag (gtag.js) - Google Analytics