问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

sql date函数

发布网友 发布时间:2022-05-02 00:00

我来回答

2个回答

懂视网 时间:2022-05-02 04:21

 

TO_DATE格式(以时间:2007-11-02   13:45:25为例)

Year:      
yy two digits 两位年                显示值:07
yyy three digits 三位年                显示值:007
yyyy four digits 四位年                显示值:2007

Month:      
mm    number     两位月              显示值:11
mon    abbreviated 字符集表示          显示值:11月,若是英文版,显示nov     
month spelled out 字符集表示          显示值:11月,若是英文版,显示november 

Day:      
dd    number         当月第几天        显示值:02
ddd    number         当年第几天        显示值:02
dy    abbreviated 当周第几天简写    显示值:星期五,若是英文版,显示fri
day    spelled out   当周第几天全写    显示值:星期五,若是英文版,显示friday        
ddspth spelled out, ordinal twelfth 

Hour:
hh    two digits 12小时进制            显示值:01
hh24 two digits 24小时进制            显示值:13

Minute:
mi    two digits 60进制                显示值:45

Second:
ss    two digits 60进制                显示值:25

其它
Q     digit         季度                  显示值:4
WW    digit         当年第几周            显示值:44
W    digit          当月第几周            显示值:1

24小时格式下时间范围为: 0:00:00 - 23:59:59....      
12小时格式下时间范围为: 1:00:00 - 12:59:59 .... 

1. 日期和字符转换函数用法(to_date,to_char)

select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘) as nowTime from dual;   //日期转化为字符串   
select to_char(sysdate,‘yyyy‘) as nowYear   from dual;   //获取时间的年   
select to_char(sysdate,‘mm‘)    as nowMonth from dual;   //获取时间的月   
select to_char(sysdate,‘dd‘)    as nowDay    from dual;   //获取时间的日   
select to_char(sysdate,‘hh24‘) as nowHour   from dual;   //获取时间的时   
select to_char(sysdate,‘mi‘)    as nowMinute from dual;   //获取时间的分   
select to_char(sysdate,‘ss‘)    as nowSecond from dual;   //获取时间的秒

    
select to_date(‘2004-05-07 13:23:44‘,‘yyyy-mm-dd hh24:mi:ss‘)    from dual//

2.      
select to_char( to_date(222,‘J‘),‘Jsp‘) from dual      

显示Two Hundred Twenty-Two    

3.求某天是星期几      
select to_char(to_date(‘2002-08-26‘,‘yyyy-mm-dd‘),‘day‘) from dual;      
星期一      
select to_char(to_date(‘2002-08-26‘,‘yyyy-mm-dd‘),‘day‘,‘NLS_DATE_LANGUAGE = American‘) from dual;      
monday      
设置日期语言      
ALTER SESSION SET NLS_DATE_LANGUAGE=‘AMERICAN‘;      
也可以这样      
TO_DATE (‘2002-08-26‘, ‘YYYY-mm-dd‘, ‘NLS_DATE_LANGUAGE = American‘)    

4. 两个日期间的天数      
select floor(sysdate - to_date(‘20020405‘,‘yyyymmdd‘)) from dual;    

5. 时间为null的用法      
select id, active_date from table1      
UNION      
select 1, TO_DATE(null) from dual;      

注意要用TO_DATE(null)    

6.月份差   
a_date between to_date(‘20011201‘,‘yyyymmdd‘) and to_date(‘20011231‘,‘yyyymmdd‘)      
那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。      
所以,当时间需要精确的时候,觉得to_char还是必要的 

7. 日期格式冲突问题      
输入的格式要看你安装的Oracle字符集的类型, 比如: US7ASCII, date格式的类型就是: ‘01-Jan-01‘      
alter system set NLS_DATE_LANGUAGE = American      
alter session set NLS_DATE_LANGUAGE = American      
或者在to_date中写      
select to_char(to_date(‘2002-08-26‘,‘yyyy-mm-dd‘),‘day‘,‘NLS_DATE_LANGUAGE = American‘) from dual;      
注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,      
可查看      
select * from nls_session_parameters      
select * from V$NLS_PARAMETERS    

8.      
select count(*)      
from ( select rownum-1 rnum      
from all_objects      
where rownum <= to_date(‘2002-02-28‘,‘yyyy-mm-dd‘) - to_date(‘2002-      
02-01‘,‘yyyy-mm-dd‘)+1      
)      
where to_char( to_date(‘2002-02-01‘,‘yyyy-mm-dd‘)+rnum-1, ‘D‘ )      
not in ( ‘1‘, ‘7‘ )      

查找2002-02-28至2002-02-01间除星期一和七的天数      
在前后分别调用DBMS_UTILITY.GET_TIME, 让后将结果相减(得到的是1/100秒, 而不是毫秒).    

9. 查找月份     
select months_between(to_date(‘01-31-1999‘,‘MM-DD-YYYY‘),to_date(‘12-31-1998‘,‘MM-DD-YYYY‘)) "MONTHS" FROM DUAL;      
1      
select months_between(to_date(‘02-01-1999‘,‘MM-DD-YYYY‘),to_date(‘12-31-1998‘,‘MM-DD-YYYY‘)) "MONTHS" FROM DUAL;      
1.03225806451613 

10. Next_day的用法      
Next_day(date, day)      

Monday-Sunday, for format code DAY      
Mon-Sun, for format code DY      
1-7, for format code D    

11      
select to_char(sysdate,‘hh:mi:ss‘) TIME from all_objects      
注意:第一条记录的TIME 与最后一行是一样的      
可以建立一个函数来处理这个问题      
create or replace function sys_date return date is      
begin      
return sysdate;      
end;      

select to_char(sys_date,‘hh:mi:ss‘) from all_objects;   

12.获得小时数      
extract()找出日期或间隔值的字段值
SELECT EXTRACT(HOUR FROM TIMESTAMP ‘2001-02-16 2:38:40‘) from offer      
SQL> select sysdate ,to_char(sysdate,‘hh‘) from dual;      

SYSDATE TO_CHAR(SYSDATE,‘HH‘)      
-------------------- ---------------------      
2003-10-13 19:35:21 07      

SQL> select sysdate ,to_char(sysdate,‘hh24‘) from dual;      

SYSDATE TO_CHAR(SYSDATE,‘HH24‘)      
-------------------- -----------------------      
2003-10-13 19:35:21 19    

       
13.年月日的处理      
select older_date,      
newer_date,      
years,      
months,      
abs(      
trunc(      
newer_date-      
add_months( older_date,years*12+months )      
)      
) days 

from ( select      
trunc(months_between( newer_date, older_date )/12) YEARS,      
mod(trunc(months_between( newer_date, older_date )),12 ) MONTHS,      
newer_date,      
older_date      
from ( 
select hiredate older_date, add_months(hiredate,rownum)+rownum newer_date      
from emp 
)      
)    

14.处理月份天数不定的办法      
select to_char(add_months(last_day(sysdate) +1, -2), ‘yyyymmdd‘),last_day(sysdate) from dual    

16.找出今年的天数      
select add_months(trunc(sysdate,‘year‘), 12) - trunc(sysdate,‘year‘) from dual    

   闰年的处理方法      
to_char( last_day( to_date(‘02‘    | | :year,‘mmyyyy‘) ), ‘dd‘ )      
如果是28就不是闰年    

17.yyyy与rrrr的区别      
‘YYYY99 TO_C      
------- ----      
yyyy 99 0099      
rrrr 99 1999      
yyyy 01 0001      
rrrr 01 2001    

18.不同时区的处理      
select to_char( NEW_TIME( sysdate, ‘GMT‘,‘EST‘), ‘dd/mm/yyyy hh:mi:ss‘) ,sysdate      
from dual;    

19.5秒钟一个间隔      
Select TO_DATE(FLOOR(TO_CHAR(sysdate,‘SSSSS‘)/300) * 300,‘SSSSS‘) ,TO_CHAR(sysdate,‘SSSSS‘)      
from dual    

   2002-11-1 9:55:00 35786      
SSSSS表示5位秒数    

20.一年的第几天      
select TO_CHAR(SYSDATE,‘DDD‘),sysdate from dual

310 2002-11-6 10:03:51    

21.计算小时,分,秒,毫秒      
select      
Days,      
A,      
TRUNC(A*24) Hours,      
TRUNC(A*24*60 - 60*TRUNC(A*24)) Minutes,      
TRUNC(A*24*60*60 - 60*TRUNC(A*24*60)) Seconds,      
TRUNC(A*24*60*60*100 - 100*TRUNC(A*24*60*60)) mSeconds      
from      
(      
select      
trunc(sysdate) Days,      
sysdate - trunc(sysdate) A      
from dual      
)    


   select * from tabname      
order by decode(mode,‘FIFO‘,1,-1)*to_char(rq,‘yyyymmddhh24miss‘);      

//      
floor((date2-date1) /365) 作为年      
floor((date2-date1, 365) /30) 作为月      
d(mod(date2-date1, 365), 30)作为日.

23.next_day函数      返回下个星期的日期,day为1-7或星期日-星期六,1表示星期日
next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。      
1 2 3 4 5 6 7      
日 一 二 三 四 五 六    

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

select    (sysdate-to_date(‘2003-12-03 12:55:45‘,‘yyyy-mm-dd hh24:mi:ss‘))*24*60*60 from ddual
日期 返回的是天 然后 转换为ss

24,round[舍入到最接近的日期](day:舍入到最接近的星期日)
select sysdate S1,
round(sysdate) S2 ,
round(sysdate,‘year‘) YEAR,
round(sysdate,‘month‘) MONTH ,
round(sysdate,‘day‘) DAY from dual

25,trunc[截断到最接近的日期,单位为天] ,返回的是日期类型
select sysdate S1,                     
trunc(sysdate) S2,                 //返回当前日期,无时分秒
trunc(sysdate,‘year‘) YEAR,        //返回当前年的1月1日,无时分秒
trunc(sysdate,‘month‘) MONTH ,     //返回当前月的1日,无时分秒
trunc(sysdate,‘day‘) DAY           //返回当前星期的星期天,无时分秒
from dual

26,返回日期列表中最晚日期
select greatest(‘01-1月-04‘,‘04-1月-04‘,‘10-2月-04‘) from dual

27.计算时间差
注:oracle时间差是以天数为单位,所以换算成年月,日

select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))/365) as spanYears from dual        //时间差-年
select ceil(moths_between(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))) as spanMonths from dual        //时间差-月
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))) as spanDays from dual             //时间差-天
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))*24) as spanHours from dual         //时间差-时
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))*24*60) as spanMinutes from dual    //时间差-分
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))*24*60*60) as spanSeconds from dual //时间差-秒

28.更新时间
注:oracle时间加减是以天数为单位,设改变量为n,所以换算成年月,日
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n*365,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual        //改变时间-年
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),add_months(sysdate,n) as newTime from dual                                 //改变时间-月
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual            //改变时间-日
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n/24,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual         //改变时间-时
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n/24/60,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual      //改变时间-分
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n/24/60/60,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual   //改变时间-秒

29.查找月的第一天,最后一天
SELECT Trunc(Trunc(SYSDATE, ‘MONTH‘) - 1, ‘MONTH‘) First_Day_Last_Month,
Trunc(SYSDATE, ‘MONTH‘) - 1 / 86400 Last_Day_Last_Month,
Trunc(SYSDATE, ‘MONTH‘) First_Day_Cur_Month,
LAST_DAY(Trunc(SYSDATE, ‘MONTH‘)) + 1 - 1 / 86400 Last_Day_Cur_Month
FROM dual;

INSERT  INTO  FLOOR  VALUES  ( to_date ( ‘2007-12-20 18:31:34‘ , ‘YYYY-MM-DD HH24:MI:SS‘ ) ) ; 
查询显示:2007-12-20 18:31:34.0 
------------------- 
INSERT  INTO  FLOOR  VALUES  ( to_date ( ‘2007-12-14 14:10‘ , ‘YYYY-MM-DD HH24:MI‘ ) ); 
查询显示:2007-12-14 14:10:00.0 
------------------- 
INSERT  INTO  FLOOR  VALUES  ( to_date ( ‘2007-12-14 14‘ , ‘YYYY-MM-DD HH24‘ ) ); 
查询显示:2007-12-14 14:00:00.0 
------------------- 
INSERT  INTO  FLOOR  VALUES  ( to_date ( ‘2007-11-15‘ , ‘YYYY-MM-DD‘ ) ); 
查询显示:2007-11-15 00:00:00.0 
------------------- 
INSERT  INTO  FLOOR  VALUES  ( to_date ( ‘2007-09‘ , ‘YYYY-MM‘ ) ); 
查询显示:2007-09-01 00:00:00.0 
------------------- 
INSERT  INTO  FLOOR  VALUES  ( to_date ( ‘2007‘ , ‘YYYY‘ ) ); 
查询显示:2007-05-01 00:00:00.0 
------------------- 

当省略HH、MI和SS对应的输入参数时,Oracle使用0作为DEFAULT值。 
如果输入的日期数据忽略时间部分,Oracle会将时、分、秒部分都置为0,也就是说会取整到日。 
同样,忽略了DD参数,Oracle会采用1作为日的默认值,也就是说会取整到月。 
但是,不要被这种“惯性”所迷惑,如果忽略MM参数,Oracle并不会取整到年,而是取整到当前月

 

TO_DATE格式(以时间:2007-11-02   13:45:25为例)

Year:      
yy two digits 两位年                显示值:07
yyy three digits 三位年                显示值:007
yyyy four digits 四位年                显示值:2007

Month:      
mm    number     两位月              显示值:11
mon    abbreviated 字符集表示          显示值:11月,若是英文版,显示nov     
month spelled out 字符集表示          显示值:11月,若是英文版,显示november 

Day:      
dd    number         当月第几天        显示值:02
ddd    number         当年第几天        显示值:02
dy    abbreviated 当周第几天简写    显示值:星期五,若是英文版,显示fri
day    spelled out   当周第几天全写    显示值:星期五,若是英文版,显示friday        
ddspth spelled out, ordinal twelfth 

Hour:
hh    two digits 12小时进制            显示值:01
hh24 two digits 24小时进制            显示值:13

Minute:
mi    two digits 60进制                显示值:45

Second:
ss    two digits 60进制                显示值:25

其它
Q     digit         季度                  显示值:4
WW    digit         当年第几周            显示值:44
W    digit          当月第几周            显示值:1

24小时格式下时间范围为: 0:00:00 - 23:59:59....      
12小时格式下时间范围为: 1:00:00 - 12:59:59 .... 

1. 日期和字符转换函数用法(to_date,to_char)

select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘) as nowTime from dual;   //日期转化为字符串   
select to_char(sysdate,‘yyyy‘) as nowYear   from dual;   //获取时间的年   
select to_char(sysdate,‘mm‘)    as nowMonth from dual;   //获取时间的月   
select to_char(sysdate,‘dd‘)    as nowDay    from dual;   //获取时间的日   
select to_char(sysdate,‘hh24‘) as nowHour   from dual;   //获取时间的时   
select to_char(sysdate,‘mi‘)    as nowMinute from dual;   //获取时间的分   
select to_char(sysdate,‘ss‘)    as nowSecond from dual;   //获取时间的秒

    
select to_date(‘2004-05-07 13:23:44‘,‘yyyy-mm-dd hh24:mi:ss‘)    from dual//

2.      
select to_char( to_date(222,‘J‘),‘Jsp‘) from dual      

显示Two Hundred Twenty-Two    

3.求某天是星期几      
select to_char(to_date(‘2002-08-26‘,‘yyyy-mm-dd‘),‘day‘) from dual;      
星期一      
select to_char(to_date(‘2002-08-26‘,‘yyyy-mm-dd‘),‘day‘,‘NLS_DATE_LANGUAGE = American‘) from dual;      
monday      
设置日期语言      
ALTER SESSION SET NLS_DATE_LANGUAGE=‘AMERICAN‘;      
也可以这样      
TO_DATE (‘2002-08-26‘, ‘YYYY-mm-dd‘, ‘NLS_DATE_LANGUAGE = American‘)    

4. 两个日期间的天数      
select floor(sysdate - to_date(‘20020405‘,‘yyyymmdd‘)) from dual;    

5. 时间为null的用法      
select id, active_date from table1      
UNION      
select 1, TO_DATE(null) from dual;      

注意要用TO_DATE(null)    

6.月份差   
a_date between to_date(‘20011201‘,‘yyyymmdd‘) and to_date(‘20011231‘,‘yyyymmdd‘)      
那么12月31号中午12点之后和12月1号的12点之前是不包含在这个范围之内的。      
所以,当时间需要精确的时候,觉得to_char还是必要的 

7. 日期格式冲突问题      
输入的格式要看你安装的ORACLE字符集的类型, 比如: US7ASCII, date格式的类型就是: ‘01-Jan-01‘      
alter system set NLS_DATE_LANGUAGE = American      
alter session set NLS_DATE_LANGUAGE = American      
或者在to_date中写      
select to_char(to_date(‘2002-08-26‘,‘yyyy-mm-dd‘),‘day‘,‘NLS_DATE_LANGUAGE = American‘) from dual;      
注意我这只是举了NLS_DATE_LANGUAGE,当然还有很多,      
可查看      
select * from nls_session_parameters      
select * from V$NLS_PARAMETERS    

8.      
select count(*)      
from ( select rownum-1 rnum      
from all_objects      
where rownum <= to_date(‘2002-02-28‘,‘yyyy-mm-dd‘) - to_date(‘2002-      
02-01‘,‘yyyy-mm-dd‘)+1      
)      
where to_char( to_date(‘2002-02-01‘,‘yyyy-mm-dd‘)+rnum-1, ‘D‘ )      
not in ( ‘1‘, ‘7‘ )      

查找2002-02-28至2002-02-01间除星期一和七的天数      
在前后分别调用DBMS_UTILITY.GET_TIME, 让后将结果相减(得到的是1/100秒, 而不是毫秒).    

9. 查找月份     
select months_between(to_date(‘01-31-1999‘,‘MM-DD-YYYY‘),to_date(‘12-31-1998‘,‘MM-DD-YYYY‘)) "MONTHS" FROM DUAL;      
1      
select months_between(to_date(‘02-01-1999‘,‘MM-DD-YYYY‘),to_date(‘12-31-1998‘,‘MM-DD-YYYY‘)) "MONTHS" FROM DUAL;      
1.03225806451613 

10. Next_day的用法      
Next_day(date, day)      

Monday-Sunday, for format code DAY      
Mon-Sun, for format code DY      
1-7, for format code D    

11      
select to_char(sysdate,‘hh:mi:ss‘) TIME from all_objects      
注意:第一条记录的TIME 与最后一行是一样的      
可以建立一个函数来处理这个问题      
create or replace function sys_date return date is      
begin      
return sysdate;      
end;      

select to_char(sys_date,‘hh:mi:ss‘) from all_objects;   

12.获得小时数      
extract()找出日期或间隔值的字段值
SELECT EXTRACT(HOUR FROM TIMESTAMP ‘2001-02-16 2:38:40‘) from offer      
SQL> select sysdate ,to_char(sysdate,‘hh‘) from dual;      

SYSDATE TO_CHAR(SYSDATE,‘HH‘)      
-------------------- ---------------------      
2003-10-13 19:35:21 07      

SQL> select sysdate ,to_char(sysdate,‘hh24‘) from dual;      

SYSDATE TO_CHAR(SYSDATE,‘HH24‘)      
-------------------- -----------------------      
2003-10-13 19:35:21 19    

       
13.年月日的处理      
select older_date,      
newer_date,      
years,      
months,      
abs(      
trunc(      
newer_date-      
add_months( older_date,years*12+months )      
)      
) days 

from ( select      
trunc(months_between( newer_date, older_date )/12) YEARS,      
mod(trunc(months_between( newer_date, older_date )),12 ) MONTHS,      
newer_date,      
older_date      
from ( 
select hiredate older_date, add_months(hiredate,rownum)+rownum newer_date      
from emp 
)      
)    

14.处理月份天数不定的办法      
select to_char(add_months(last_day(sysdate) +1, -2), ‘yyyymmdd‘),last_day(sysdate) from dual    

16.找出今年的天数      
select add_months(trunc(sysdate,‘year‘), 12) - trunc(sysdate,‘year‘) from dual    

   闰年的处理方法      
to_char( last_day( to_date(‘02‘    | | :year,‘mmyyyy‘) ), ‘dd‘ )      
如果是28就不是闰年    

17.yyyy与rrrr的区别      
‘YYYY99 TO_C      
------- ----      
yyyy 99 0099      
rrrr 99 1999      
yyyy 01 0001      
rrrr 01 2001    

18.不同时区的处理      
select to_char( NEW_TIME( sysdate, ‘GMT‘,‘EST‘), ‘dd/mm/yyyy hh:mi:ss‘) ,sysdate      
from dual;    

19.5秒钟一个间隔      
Select TO_DATE(FLOOR(TO_CHAR(sysdate,‘SSSSS‘)/300) * 300,‘SSSSS‘) ,TO_CHAR(sysdate,‘SSSSS‘)      
from dual    

   2002-11-1 9:55:00 35786      
SSSSS表示5位秒数    

20.一年的第几天      
select TO_CHAR(SYSDATE,‘DDD‘),sysdate from dual

310 2002-11-6 10:03:51    

21.计算小时,分,秒,毫秒      
select      
Days,      
A,      
TRUNC(A*24) Hours,      
TRUNC(A*24*60 - 60*TRUNC(A*24)) Minutes,      
TRUNC(A*24*60*60 - 60*TRUNC(A*24*60)) Seconds,      
TRUNC(A*24*60*60*100 - 100*TRUNC(A*24*60*60)) mSeconds      
from      
(      
select      
trunc(sysdate) Days,      
sysdate - trunc(sysdate) A      
from dual      
)    


   select * from tabname      
order by decode(mode,‘FIFO‘,1,-1)*to_char(rq,‘yyyymmddhh24miss‘);      

//      
floor((date2-date1) /365) 作为年      
floor((date2-date1, 365) /30) 作为月      
d(mod(date2-date1, 365), 30)作为日.

23.next_day函数      返回下个星期的日期,day为1-7或星期日-星期六,1表示星期日
next_day(sysdate,6)是从当前开始下一个星期五。后面的数字是从星期日开始算起。      
1 2 3 4 5 6 7      
日 一 二 三 四 五 六    

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

select    (sysdate-to_date(‘2003-12-03 12:55:45‘,‘yyyy-mm-dd hh24:mi:ss‘))*24*60*60 from ddual
日期 返回的是天 然后 转换为ss

24,round[舍入到最接近的日期](day:舍入到最接近的星期日)
select sysdate S1,
round(sysdate) S2 ,
round(sysdate,‘year‘) YEAR,
round(sysdate,‘month‘) MONTH ,
round(sysdate,‘day‘) DAY from dual

25,trunc[截断到最接近的日期,单位为天] ,返回的是日期类型
select sysdate S1,                     
trunc(sysdate) S2,                 //返回当前日期,无时分秒
trunc(sysdate,‘year‘) YEAR,        //返回当前年的1月1日,无时分秒
trunc(sysdate,‘month‘) MONTH ,     //返回当前月的1日,无时分秒
trunc(sysdate,‘day‘) DAY           //返回当前星期的星期天,无时分秒
from dual

26,返回日期列表中最晚日期
select greatest(‘01-1月-04‘,‘04-1月-04‘,‘10-2月-04‘) from dual

27.计算时间差
注:oracle时间差是以天数为单位,所以换算成年月,日

select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))/365) as spanYears from dual        //时间差-年
select ceil(moths_between(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))) as spanMonths from dual        //时间差-月
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))) as spanDays from dual             //时间差-天
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))*24) as spanHours from dual         //时间差-时
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))*24*60) as spanMinutes from dual    //时间差-分
select floor(to_number(sysdate-to_date(‘2007-11-02 15:55:03‘,‘yyyy-mm-dd hh24:mi:ss‘))*24*60*60) as spanSeconds from dual //时间差-秒

28.更新时间
注:oracle时间加减是以天数为单位,设改变量为n,所以换算成年月,日
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n*365,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual        //改变时间-年
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),add_months(sysdate,n) as newTime from dual                                 //改变时间-月
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual            //改变时间-日
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n/24,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual         //改变时间-时
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n/24/60,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual      //改变时间-分
select to_char(sysdate,‘yyyy-mm-dd hh24:mi:ss‘),to_char(sysdate+n/24/60/60,‘yyyy-mm-dd hh24:mi:ss‘) as newTime from dual   //改变时间-秒

29.查找月的第一天,最后一天
SELECT Trunc(Trunc(SYSDATE, ‘MONTH‘) - 1, ‘MONTH‘) First_Day_Last_Month,
Trunc(SYSDATE, ‘MONTH‘) - 1 / 86400 Last_Day_Last_Month,
Trunc(SYSDATE, ‘MONTH‘) First_Day_Cur_Month,
LAST_DAY(Trunc(SYSDATE, ‘MONTH‘)) + 1 - 1 / 86400 Last_Day_Cur_Month
FROM dual;

sql_date

标签:插入   sel   mon   ret   ascii   英文版   minutes   默认   tar   

热心网友 时间:2022-05-02 01:29

日期/时间的格式化[字符串转换为日期]

Oracle
SQL> SELECT
2 TO_DATE('2010.10.01', 'YYYY.MM.DD')
3 FROM
4 al;

TO_DATE('2
----------
2010.10.01

SQL Server
1> SELECT
2> CONVERT(DATETIME, '2012-01-02 09:06:18', 120)
3> go

-----------------------
2012-01-02 09:06:18.000

(1 行受影响)

MySQL
mysql> SELECT
-> STR_TO_DATE('2010~10~22 20.55.09',
-> '%Y~%m~%d %k.%i.%s' ) A;
+---------------------+
| A |
+---------------------+
| 2010-10-22 20:55:09 |
+---------------------+
1 row in set (0.00 sec)
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
儿歌祖国妈妈我爱你是谁写的汇总28句 为什么有的人学几何很厉害数学却不行 一个人数学几何好,但是其他计算方面的都马马虎虎,那么说明这个人怎么... 数学几何好的人,就是一道几何题很快就能想出来的人是不很聪明?这能练... 固安尚城国际怎么样 驾驶员咨询服务营业执照经营范围怎么写 驾校属于什么经营范围 核桃粉保质期多长时间 亿生康宝筋骨冷敷凝胶只在国内销售吗? 清河镇概况 优酷客户端怎么会经常自动关闭啊? 为什么优酷会自动退出 为什么优酷客户端无法关闭 上海教育电视台播放李静和戴军主持的超级访问的具体时间 上海教育电视台这么走??? 上海有几个电视台?几个频道啊? 上海教育台播出和结束时间 上海有多少个本地电视频道?分别是哪些台? 没有手机卡怎么找回原来的 这不是斯巴达和斯巴达300勇士是同一个人演的吗 四川最好的骨科医院是哪家 请问四川大学包括华西 有几个院士啊? 成都华西附属四医院可以洗肺吗 成都市沙湾路到成都市华西附四医院 从代练通上下的单子 然后这个不是同一个人打的嘛?这算是什么情况? 请问歌词里面有,原来我不是一个人,这首歌叫什么名字啊? 华西附四院护士待遇怎样 2022华西公共卫生硕士招生人数 这两人是不是同一人啊 四川大学华西院和它的四个附属医院的关系具体体现在什么地方 父母出外```杯面扫空```现在家中就只有鸡腿和鸡翅膀在急冻中```请问怎么可以用微波炉解冻和煮呢```? 用国家名称,城市名称写一段搞笑又合理的话。 如:今天,我去肯德基吃汉堡和奥尔良烤翅,结果把西班牙啃了 关于烧烤途中铁网发黑有什么处理办法 成年人受到惊吓有什么症状 成人惊吓后遗症有什么具体表现? 大人被吓到了有什么症状 惊吓过度一般到成年后会有什么后遗症?后遗状态下应该如何调理恢复正常?? 大人不“吓着”了怎么半?怎么摸“吓着”?教教我 大人被吓着了,晚上睡觉总是惊醒 vivox5pro安装了软件后,会自动删除安装包,怎么关闭自动删除? vivo手机怎么设置安装程序不保留安装包 白手起家3年挣300万淘宝创业故事分享 跑分50万的电脑很老了吗? 电脑跑分40w但是核心跑分低,我这属于很低端的电脑吗? 跑分40万的笔记本,玩steam里gta5,彩6等,开高画质,卡吗?FPS大概有多少啊? 创业故事:马云是怎样白手起家的 电脑跑分40w能玩和平精英吗? 跑分40万的台式电脑玩电脑版我的世界卡吗? 一万六的笔记本跑分38~40万性价比怎么样 i7 8700&#47;英特尔40万跑分&#47;GTX1070&#47;DDR4内存吃鸡游戏台式DIY组装电脑主机 可以开快手直播吃鸡不?