1、关于trunc 和round函数比较

整体概括:

round函数 四舍五入
trunc函数 直接截取

对于时间:

Round函数对日期进行“四舍五入”,Trunc函数对日期进行截取。如果我们不指定格式的话,Round会返回一个最接近date参数的日期,而Trunc函数只会简单的截取时分秒部分,返回年月日部分

对于数字:

Round函数对数字同样进行“四舍五入”,Trunc函数截取时不进行四舍五入,可以指明保留小数点后面的位数。

2、Round、Trunc用法

    1. /**************************For date****************************/
    2. --Trunc函数
    3. SELECT TRUNC(SYSDATE), -- 今天的日期为  2014-05-08
    4. TRUNC(SYSDATE, 'YYYY'), --返回当年第一天 2014-01-01  yyyy/yy/year 年
    5. TRUNC(SYSDATE, 'MM'), --返回当月第一天  2014-05-01   mm/month     月
    6. TRUNC(SYSDATE, 'DD'), --返回当前年月日 2014-05-08    d/day        周
    7. TRUNC(SYSDATE, 'D'), --(星期天)返回当前星期的第一天 2014-05-04
    8. TRUNC(SYSDATE, 'HH'), --返回当前时间精确小时  2014-05-08 11:00:00
    9. TRUNC(SYSDATE, 'MI') -- 返回当前时间精确分钟  2014-05-08 11:06:00  TRUNC()函数没有秒的精确
    10. FROM DUAL;
    11. --Round函数
    12. select Round(sysdate, 'Q') Rnd_Q, --2014-04-01
    13. Round(sysdate, 'Month') Rnd_Month, --2014-05-01
    14. Round(sysdate, 'WW') Rnd_Week, --2014-05-07
    15. Round(sysdate, 'W') Rnd_Week_again, --2014-05-08
    16. Round(sysdate, 'DDD') Rnd_day, --2014-05-08
    17. Round(sysdate, 'DD') Rnd_day_again, --2014-05-08
    18. Round(sysdate, 'DAY') Rnd_day_of_week, --2014-05-11
    19. Round(sysdate, 'D') Rnd_day_of_week_again, --2014-05-11
    20. Round(sysdate, 'HH12') Rnd_hour_12, --2014-05-08 12:00:00
    21. Round(sysdate, 'HH24') Rnd_hour_24, --2014-05-08 12:00:00
    22. Round(sysdate, 'MI') Rnd_minute --2014-05-08 11:52:00
    23. from dual;
    24. /****************************For number************************/
    25. /**
    26. --TRUNC(number,num_digits)
    27. Number 需要截尾取整的数字。
    28. Num_digits  指明需保留小数点后面的位数。可选项,忽略他则截去任何的小数部分,Num_digits 的默认值为 0,
    29. --此参数够为负数,表示为小数点左边指定位数后面的部分截去,即均以0记。
    30. TRUNC()函数截取时不进行四舍五入**/
    31. --TRUNC函数
    32. select TRUNC(123.458), --123
    33. TRUNC(123.458, 0), --123
    34. TRUNC(123.458, 1), --123.4
    35. TRUNC(123.458, 2), --123.45
    36. TRUNC(123.458, 3), --123.458
    37. TRUNC(123.458, 4), --123.458
    38. TRUNC(123.458, -1), --120
    39. TRUNC(123.458, -2), --100
    40. TRUNC(123.458, -3), --0
    41. TRUNC(123.458, -4), --0
    42. TRUNC(123), --123
    43. TRUNC(123, 1), --123
    44. TRUNC(123, 2), --123
    45. TRUNC(123, 3), --123
    46. TRUNC(123, 4) --123
    47. from dual;
    48. --Round函数
    49. select Round(123.458), --123
    50. Round(123.458, 0), --123
    51. Round(123.458, 1), --123.5
    52. Round(123.458, 2), --123.46
    53. Round(123.458, 3), --123.458
    54. Round(123.458, 4), --123.458
    55. Round(123.458, -1), --120
    56. Round(123.458, -2), --100
    57. Round(123.458, -3), --0
    58. Round(123.458, -4), --0
    59. Round(123), --123
    60. Round(123, 1), --123
    61. Round(123, 2), --123
    62. Round(123, 3), --123
    63. Round(123, 4) --123
    64. from dual;

round(x[,y]) 
【功能】返回四舍五入后的值 
【参数】x,y,数字型表达式,如果y不为整数则截取y整数部分,如果y>0则四舍五入为y位小数,如果y小于0则四舍五入到小数点向左第y位。 
【返回】数字 
【示例】 select round(5555.6666,2.1),round(5555.6666,-2.6),round(5555.6666) from dual; 
返回: 5555.67 , 5600 , 5556 
【相近】trunc(x[,y]) 返回截取后的值,用法同round(x[,y]),只是不四舍五入 

trunc(x[,y]) 
【功能】返回x按精度y截取后的值 
【参数】x,y,数字型表达式,如果y不为整数则截取y整数部分,如果y>0则截取到y位小数,如果y小于0则截取到小数点向左第y位,小数前其它数据用0表示。 
【返回】数字 
【示例】 select trunc(5555.66666,2.1),trunc(5555.66666,-2.6),trunc(5555.033333) from dual; 
返回:5555.66 5500 5555 
【相近】round(x[,y]) 返回截取后的值,用法同trunc(x[,y]),只是要做四舍五入

Oracle trunc和round的区别的更多相关文章

  1. 【测试】trunc和round的区别

    trunc是截断:round是四舍五入:下面通过一个例子具体看一下trunc和round的不同 SQL),trunc() from dual; TRUNC() TRUNC() ------------ ...

  2. Oracle trunc()函数的用法及四舍五入 round函数

    --Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual  --2011 ...

  3. Oracle trunc函数

    --Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysdate) from dual  --2011 ...

  4. Oracle trunc()函数的用法--来着心静禅定ing

    1.TRUNC(for dates) TRUNC函数为指定元素而截去的日期值. 其具体的语法格式如下: TRUNC(date[,fmt]) 其中: date 一个日期值 fmt 日期格式,该日期将由指 ...

  5. [转]Oracle trunc()函数的用法

    原文地址:http://www.cnblogs.com/gengaixue/archive/2012/11/21/2781037.html 1.TRUNC(for dates) TRUNC函数为指定元 ...

  6. Oracle trunc()函数的用法

    Oracle trunc()函数的用法 /**************日期********************/1.select trunc(sysdate) from dual --2013-0 ...

  7. oracle的oci和thin区别(数据源)

    我是今天看到tomcat数据源的配置时,想起来这个问题,刚开始还不晓得thin是什么东西! database.url=jdbc:oracle:thin:angel/oracle@192.168.55. ...

  8. oracle获取本月第一天和最后一天及Oracle trunc()函数的用法

    select to_char(trunc(add_months(last_day(sysdate), -1) + 1), 'yyyy-mm-dd') "本月第一天", to_cha ...

  9. Oracle trunc()函数

    Oracle trunc()函数的用法   --Oracle trunc()函数的用法/**************日期********************/1.select trunc(sysd ...

随机推荐

  1. 【.NET 与树莓派】用 MPD 制作数字音乐播放器

    树莓派的日常家居玩法多多,制作一台属于自己的数字音乐播放机是其中的一种.严格上说,树莓派是没有声卡的,其板载的 3.5 mm 音频孔实际是通过 PWM 来实现音频输出的(通过算法让PWM信号变成模拟信 ...

  2. 2021 祥云杯 wp

    52 web ezyii https://pan.baidu.com/s/1j7IJm9xiea5FvBhPMkPNoQ 提取码GAME <?php include("closure/ ...

  3. Linux 软连接与硬连接 区别

    先说结论 软连接相当于快捷方式,访问软连接会被替换为其指向的绝对路径,如果其指向的文件被删除,则无法访问. 硬连接相当于指针,与它指向的文件都指向相同的inode,当其指向的文件被删除,inode由于 ...

  4. [atAGC054D]ox

    对于两个字符串$s$和$t$(保证其中每一种字符个数相同),定义$s$和$t$的相对逆序对数为$s$得到$t$的最少交换次数,显然同种字符相对顺序保持不变,因此即依次编号后的逆序对数 问题不妨看作构造 ...

  5. [cf741C]Arpa’s overnight party and Mehrdad’s silent entering

    直接令2i-1和2i的位置不相同,相当于有2n条边,对其进行二分图染色即可(这张图一定不存在奇环). 假设给出的n条关系是A类边,2i-1和2i的边是B类边,可以发现一条路径一定是AB交替(因为A/B ...

  6. [atARC094F]Normalization

    考虑$s$能变成$t$的必要条件(假设$s\ne t$): 1.$s$中存在一对相邻字符不同 2.$|s|=|t|$且若将a-c对应为0-2,则字符模3同余: 3.$t$中存在一对相邻两个字符相同 同 ...

  7. [cf643G]Choosing Ads

    首先对于$p>50$,有经典的做法,即不断删去区间中不同的两数,最终剩下的即为出现次数超过一半的数(或没有),用线段树维护即可 那么对于$p\le 50$,类似的,即删去区间中不同的$\lflo ...

  8. 洛谷 P4292 - [WC2010]重建计划(长链剖分+线段树)

    题面传送门 我!竟!然!独!立!A!C!了!这!道!题!incredible! 首先看到这类最大化某个分式的题目,可以套路地想到分数规划,考虑二分答案 \(mid\) 并检验是否存在合法的 \(S\) ...

  9. Codeforces 671C - Ultimate Weirdness of an Array(线段树维护+找性质)

    Codeforces 题目传送门 & 洛谷题目传送门 *2800 的 DS,不过还是被我自己想出来了 u1s1 这个 D1C 比某些 D1D 不知道难到什么地方去了 首先碰到这类问题我们肯定考 ...

  10. Java培训班学员如何找工作?如何过试用期?

    在本文里,首先将结合我了解的多家培训班辅导学员就业的情况,来讲讲培训班学员如何高效找工作.由于本人在周末会兼职在培训班讲课,也帮助过不少学员成功入职,所以下文还会给出"培训班学员如何快速适应 ...