oracle中用于返回日期和时间,oracle 中常用时间日期函数使用详解

--日期相关函数

--1.day(date_time),返回一个整数,表示指定日期的datepart中的日子。month(date_time),year(date_time)类似

SELECT DAY(getdate())  --返回23

--2.datepart(datepart,date),返回类型datetime、smalldatetime、date 或 time 值(例如,月份)中以整数表示的部分

SELECT datepart(yy,getdate())  --返回日期分量年2010

SELECT datepart(MM,getdate())  --返回日期分量月3

SELECT datepart(dd,getdate())  --返回日期分量天23

SELECT datepart(hh,getdate())  --返回日期分量时11

SELECT datepart(mi,getdate())  --返回日期分量分钟10

SELECT datepart(ss,getdate())  --返回日期分量秒55

SELECT datepart(ms,getdate())  --返回日期分量毫秒955

SELECT datepart(wd,getdate())  --返回日期分量星期3,从星期日算起

SELECT datepart(dy,getdate())  --返回日期分量一年中的第几天82,从星期日算起

--3.dateadd(datepart,number,date),返回通过向其它日期添加日期分量所产生的日期

SELECT dateadd(dd,5,getdate())

--在当前时间的日期分量——天分量上加5天(若要减5天则写为-5,其它日期分量类似),返回2010-03-28 11:10:55:955

--4.datename(datepart,date),返回类型datetime、smalldatetime、date 或 time 值中以 ASCII 字符串表示的部分

SELECT datename(dw,getdate())  --返回Tuesday

--5.datediff(datepart,startdate,enddate),返回enddate-startdate所在日期分量的的相差值,startdate-enddate为负值

SELECT datediff(hh,'2010-03-23 11:10:55:955','2010-03-23 12:05:55:955')

--返回0,因为还没相差一个小时

--由当前时间获得所在年的年初

SELECT CONVERT(datetime,CONVERT(VARCHAR(4),datepart(yy,getdate()))+'0101 00:00:00')

--由当前时间获得所在月的月初

SELECT CONVERT(datetime,CONVERT(VARCHAR(12),dateadd(dd,-datepart(dd,getdate())+1,getdate()),112)+' 00:00:00')

SELECT CONVERT(datetime,CONVERT(VARCHAR(12),dateadd(dd,-DAY(getdate())+1,getdate()),112)+' 00:00:00')

--由当前时间获得上周时间段,如当前时间20100323 11:10:55,将得到 20100315 00:00:00 至 20100322 00:00:00 ,时分秒默认为0

SELECT CONVERT(datetime,CONVERT(VARCHAR(12),dateadd(dd,-(datepart(dw,getdate())+5), getdate()),112))

SELECT CONVERT(datetime,CONVERT(VARCHAR(12),dateadd(dd,-(datepart(dw,getdate())-2), getdate()),112))

--获得日期格式为20102303

SELECT CONVERT(VARCHAR(24),getdate(),112)

--获得日期格式为2010/23/03

SELECT CONVERT(VARCHAR(24),getdate(),113)

--获得日期格式为Mar 23 2010 11:11:18:346

SELECT CONVERT(VARCHAR(24),getdate(),109)

补充一篇文章

常用日期型函数

1。Sysdate 当前日期和时间 SQL> Select sysdate from dual;

2。Last_day() 时间所在月的最后一天 SQL> Select last_day(sysdate) from dual;

3。Add_months(d,n) 当前日期d后推n个月 用于从一个日期值增加或减少一些月份          date_value:=add_months(date_value,number_of_months)

SQL> Select add_months(sysdate,2) from dual;

4。Months_between(f,s) 日期f和s间相差月数

SQL> select months_between(sysdate,to_date('2005-11-12','yyyy-mm-dd'))from dual;

5。NEXT_DAY(d, day_of_week) 返回由"day_of_week"命名的,在变量"d"指定的日期之后的第几个工作日的日期 。参数"day_of_week"必须为该星期中的某一天。

SELECT next_day(to_date('20050620','YYYYMMDD'),1) FROM dual;

select next_day(sysdate,3) from dual;表示第三工作日,外国第一个工作为周日。注意如果今天是周一,则表示这周的周二,如果这周周二已经过了,则表示下周的周二

6。current_date()返回当前会话时区中的当前日期 date_value:=current_date SQL> column sessiontimezone for a15 SQL> select sessiontimezone,current_date from dual;

SQL> alter session set time_zone='-11:00' 2 / 会话已更改。 SQL> select sessiontimezone,current_timestamp from dual;

7。current_timestamp() 以timestamp with time zone数据类型返回当前会话时区中的当前日期

SQL> select current_timestamp from dual;

8。dbtimezone()返回时区 SQL> select dbtimezone from dual;

9。extract()找出日期或间隔值的字段值 date_value:=extract(date_field from [datetime_value|interval_value])

SQL> select extract(month from sysdate) "This Month" from dual;

SQL> select extract(year from add_months(sysdate,36)) " Years" from dual;

Years ----------       2008

10。localtimestamp()返回会话中的日期和时间 SQL> select localtimestamp from dual;

LOCALTIMESTAMP---------- 21-6月 -05 10.18.15.855652 上午

11.TRUNC(for dates)

TRUNC函数为指定元素而截去的日期值。

其具体的语法格式如下:

TRUNC(date[,fmt])

其中:

date 一个日期值

fmt 日期格式,该日期将由指定的元素格式所截去。忽略它则由最近的日期截去

下面是该函数的使用情况:

1)按年截尾

select  TRUNC(TO_DATE('2008-03-01 08:23','yyyy-mm-dd hh:mi'),'yyyy')  from dual

-----------------------------------------------------------

2008-1-1

2)按月截尾

select  TRUNC(TO_DATE('2008-03-01 08:23','yyyy-mm-dd hh:mi'),'mm')  from dual

--------------------------------------------------------

2008-3-1

3)按日截尾

select  TRUNC(TO_DATE('2008-03-01 08:23','yyyy-mm-dd hh:mi'),'dd')  from dual

----------------------------------------------------------------------

2008-3-1

4)按时截尾

select  TRUNC(TO_DATE('2008-03-01 08:23','yyyy-mm-dd hh:mi'),'hh')  from dual

----------------------------------------------------------------------

2008-3-1 8:00:00

5)按分截尾

select  TRUNC(TO_DATE('2008-03-01 08:23','yyyy-mm-dd hh:mi'),'mi')  from dual

----------------------------------------------------------------------

2008-3-1 8:23:00

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值