信息发布软件,b2b软件,广告发布软件

标题: oracle trunc函数怎样才能把这个功能发挥到极致呢 [打印本页]

作者: 群发软件    时间: 2017-8-18 21:07
标题: oracle trunc函数怎样才能把这个功能发挥到极致呢
本帖最后由 群发软件 于 2017-8-18 21:10 编辑

oracle trunc函数怎样才能把这个功能发挥到极致呢

  1.TRUNC(for dates)
    TRUNC函数为指定元素而截去的日期值。
    其具体的语法格式如下:
    TRUNC(date[,fmt])
    其中:
    date 一个日期值
    fmt 日期格式,该日期将由指定的元素格式所截去。忽略它则由最近的日期截去
    下面是该函数的使用情况:
    TRUNC(TO_DATE('24-Nov-1999 08:00 pm'),'dd-mon-yyyy hh:mi am')
    ='24-Nov-1999 12:00:00 am'
    TRUNC(TO_DATE('24-Nov-1999 08:37 pm','dd-mon-yyyy hh:mi am'),'hh') ='24-Nov-1999 08:00:00 am'
    trunc(sysdate,'yyyy') --返回当年第一天。
    trunc(sysdate,'mm') --返回当月第一天。
    trunc(sysdate,'d') --返回当前星期的第一天。
    trunc(sysdate,'dd')--返回当前年月日
    2.TRUNC(for number)
    TRUNC函数返回处理后的数值,其工作机制与ROUND函数极为类似,只是该函数不对指定小数前或后的部分做相应舍入选择处理,而统统截去。
    其具体的语法格式如下
    TRUNC(number[,decimals])
    其中:
    number 待做截取处理的数值
    decimals 指明需保留小数点后面的位数。可选项,忽略它则截去所有的小数部分
    下面是该函数的使用情况:
    TRUNC(89.985,2)=89.98
    TRUNC(89.985)=89
    TRUNC(89.985,-1)=80
    注意:第二个参数可以为负数,表示为小数点左边指定位数后面的部分截去,即均以0记。与取整类似,比如参数为1即取整到十分位,如果是-1,则是取整到十位,以此类推。
--Oracle trunc()函数的用法
/**************日期********************/
1.select trunc(sysdate) from dual --2013-01-06 今天的日期为2013-01-06
2.select trunc(sysdate, 'mm') from dual --2013-01-01 返回当月第一天.
3.select trunc(sysdate,'yy') from dual --2013-01-01 返回当年第一天
4.select trunc(sysdate,'dd') from dual --2013-01-06 返回当前年月日
5.select trunc(sysdate,'yyyy') from dual --2013-01-01 返回当年第一天
6.select trunc(sysdate,'d') from dual --2013-01-06 (星期天)返回当前星期的第一天
7.select trunc(sysdate, 'hh') from dual --2013-01-06 17:00:00 当前时间为17:35
8.select trunc(sysdate, 'mi') from dual --2013-01-06 17:35:00 TRUNC()函数没有秒的精确
/***************数字********************/
/*
TRUNC(number,num_digits)
Number 需要截尾取整的数字。
Num_digits 用于指定取整精度的数字。Num_digits 的默认值为 0。
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

TRUNC函数为指定元素而截去的日期值。
  其具体的语法格式如下:
  TRUNC(date[,fmt])
  其中:
  date 一个日期值
  fmt 日期格式,该日期将由指定的元素格式所截去。忽略它则由最近的日期截去
  下面是该函数的使用情况:
  TRUNC(TO_DATE('24-Nov-1999 08:00 pm'),'dd-mon-yyyy hh:mi am')
  ='24-Nov-1999 12:00:00 am'
  TRUNC(TO_DATE('24-Nov-1999 08:37 pm','dd-mon-yyyy hh:mi am'),'hh') ='24-Nov-1999 08:00:00 am'
  trunc(sysdate,'yyyy') --返回当年第一天。
  trunc(sysdate,'mm') --返回当月第一天。
  trunc(sysdate,'d') --返回当前星期的第一天。
  trunc(sysdate,'dd')--返回当前年月日
  2.TRUNC(for number)
  TRUNC函数返回处理后的数值,其工作机制与ROUND函数极为类似,只是该函数不对指定小数前或后的部分做相应舍入选择处理,而统统截去。
  其具体的语法格式如下
  TRUNC(number[,decimals])
  其中:
  number 待做截取处理的数值
  decimals 指明需保留小数点后面的位数。可选项,忽略它则截去所有的小数部分
  下面是该函数的使用情况:
  TRUNC(89.985,2)=89.98
  TRUNC(89.985)=89
  TRUNC(89.985,-1)=80
  注意:第二个参数可以为负数,表示为小数点左边指定位数后面的部分截去,即均以0记。与取整类似,比如参数为1即取整到十分位,如果是-1,则是取整到十位,以此类推。



--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()函数没有秒的精确
/***************数字********************/
/*
TRUNC(number,num_digits)
Number 需要截尾取整的数字。
Num_digits 用于指定取整精度的数字。Num_digits 的默认值为 0。
TRUNC()函数截取时不进行四舍五入
*/


1trunc函数处理数字trunc函数返回处理后的数值,其工作机制与ROUND函数极为类似,只是该函数不对指定小数前或后的部分做相应舍入选择处理,而统统截去。其具体的语法格式如下TRUNC(number[,decimals])其中:number 待做截取处理的数值decimals 指明需保留小数点后面的位数。可选项,忽略它则截去所有的小数部分。?
1

2

3

[size=1em]selecttrunc(123.98)[size=1em]from [size=1em]dual;
[size=1em]selecttrunc(123.123,2)[size=1em]from [size=1em]dual;
[size=1em]selecttrunc(123.123,-1)[size=1em]from [size=1em]dual;




注意:第二个参数可以为负数,表示为小数点左边指定位数后面的部分截去,即均以0记。与取整类似,比如参数为1即取整到十分位,如果是-1,则是取整到十位,以此类推;如果所设置的参数为负数,且负数的位数大于或等于整数的字节数的话,则返回为0。如:TRUNC(89.985,-3)=0。1.2trunc函数处理日期trunc函数返回以指定元元素格式截去一部分的日期值。其具体的语法格式如下:TRUNC(date,[fmt])其中:date为必要参数,是输入的一个日期值fmt参数可忽略,是日期格式,用以指定的元素格式来截去输入的日期值。忽略它则由最近的日期截去下面是该函数的使用情况:?
1

2

3

4

5

6

[size=1em]trunc(sysdate,[size=1em]'yyyy'[size=1em]) [size=1em]--返回当年第一天.
[size=1em]trunc(sysdate,[size=1em]'mm'[size=1em]) [size=1em]--返回当月第一天.
[size=1em]trunc(sysdate,[size=1em]'d'[size=1em]) [size=1em]--返回当前星期的第一天.
[size=1em]selecttrunc(sysdate,[size=1em]'YYYY'[size=1em])[size=1em]from [size=1em]dual;
[size=1em]selecttrunc(sysdate,[size=1em]'MM'[size=1em])[size=1em]from [size=1em]dual;
[size=1em]selecttrunc(sysdate,[size=1em]'D'[size=1em])[size=1em]from [size=1em]dual;




2.round函数(四舍五入)描述 : 传回一个数值,该数值是按照指定的小数位元数进行四舍五入运算的结果。?
1

[size=1em]SELECT [size=1em]ROUND( number, [ decimal_places ] ) [size=1em]FROM [size=1em]DUAL




参数:number : 欲处理之数值decimal_places : 四舍五入 , 小数取几位 ( 预设为 0 )?
1

2

3

4

[size=1em]Sample :
[size=1em]select [size=1em]round(123.456, 0) [size=1em]from [size=1em]dual;          回传 123
[size=1em]select [size=1em]round(123.456, 1) [size=1em]from [size=1em]dual;          回传 123.5
[size=1em]select [size=1em]round(-123.456, 2) [size=1em]from [size=1em]dual;        回传 -123.46




3.ceil和floor函数ceil和floor函数在一些业务数据的时候,有时还是很有用的。ceil(n) 取大于等于数值n的最小整数;floor(n)取小于等于数值n的最大整数如下例子 oracle trunc函数怎样才能把这个功能发挥到极致呢 b2b软件 应用:对于每个员工,显示其加入公司的天数。?
1

2

3

[size=1em]SQL> [size=1em]select [size=1em]floor(sysdate-hiredate) [size=1em]"入职天数"[size=1em],ename [size=1em]from [size=1em]emp;
[size=1em]or
[size=1em]SQL> [size=1em]select [size=1em]trunc(sysdate-hiredate) [size=1em]"入职天数"[size=1em],ename [size=1em]from [size=1em]emp;



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]),只是要做四舍五入

作者: 1124789174    时间: 2017-8-22 05:52
挺多,客服很耐心,有导师在线指导,我这个菜鸟也能开店了,哈哈!还没有货品上架,还需要更进一步帮助,请给力支持哦!5分好评!
作者: xbaobeit    时间: 2017-8-22 17:15
及时做出评价,系统默认好评!
作者: xbaobeit    时间: 2017-8-24 02:29
好,与卖家描述的完全一致,非常满意
作者: z2340868    时间: 2017-8-24 15:31
路过,支持一下啦
作者: 乱世扶稣    时间: 2017-8-25 15:03
棒棒哒!先让他们设计一款宝贝详情,速度快不说,客服态度也好,本来不相信这些网上的东西,没想到还真特么的不错哈哈
作者: q1598188    时间: 2017-8-26 07:22
好,与卖家描述的完全一致,非常满意
作者: linshihu    时间: 2017-8-27 04:21
错。本人也很喜欢。谢谢店家了。
作者: dfgdgdfgdf    时间: 2017-9-3 17:03
功能真好,太棒了
作者: jingtai001    时间: 2017-9-7 12:56
卖家发货非常及时
作者: jh134724    时间: 2017-9-12 19:21
情的服务态度点个赞!下次有需要还会来!~
作者: 小痞子    时间: 2017-9-13 00:22
大,上手很容易,费用也合适,真心不错,每年续费方式费用低,很不错,给个5星评价!!!!
作者: 123    时间: 2017-9-15 05:58
的资料,谢谢店主
作者: 万能群发    时间: 2017-9-17 09:56
质量不错与店家的描述一样好评
作者: zdxhz    时间: 2017-9-17 17:31
卖家,好评




欢迎光临 信息发布软件,b2b软件,广告发布软件 (http://postbbs.com/) Powered by Discuz! X3.2