sql日期格式

合集下载

一些常用查询SQL语句以及显示格式

一些常用查询SQL语句以及显示格式

⼀些常⽤查询SQL语句以及显⽰格式1.查询当前年、⽉、周相关时间1.1.查询当前年份SELECT TO_CHAR(SYSDATE,'YYYY') AS YEAR FROM DUAL--查询当前年份SELECT TO_CHAR(SYSDATE,'YYY') AS YEAR FROM DUAL--查询当前年份后两位SELECT TO_CHAR(SYSDATE,'YY') AS YEAR FROM DUAL--查询当前年份最后两位SELECT TO_CHAR(SYSDATE,'Y') AS YEAR FROM DUAL--查询当前年份最后⼀位1.2.查询当前年份第⼏天SELECT TO_CHAR(SYSDATE,'DDD') AS DAYS FROM DUAL1.3.查询当前⽉份第⼏天SELECT TO_CHAR(SYSDATE,'DD') AS DAYS FROM DUAL1.4.查询当前周的星期⼏SELECT TO_CHAR(SYSDATE,'dy') AS WEEK FROM DUALSELECT TO_CHAR(SYSDATE,'day') AS WEEK FROM DUAL1.5.查询当前年的第⼏天:SELECT TO_CHAR(SYSDATE,'DDD') AS DAYS FROM DUAL2.查询当前第⼏季度SELECT TO_CHAR(SYSDATE,'Q') AS JD FROM DUAL年内是第⼏周查询当前在⼀年内是第⼏周3.查询当前在⼀SELECT TO_CHAR(SYSDATE,'IW') AS WEEKNUM FROM DUALSELECT TO_CHAR(SYSDATE,'WW') AS WEEKNUM FROM DUALSELECT TO_CHAR(SYSDATE,'W') AS WEEKNUM FROM DUAL4.查询当前某年某⽉有多少天SELECT TO_CHAR(last_day(to_date('2019/02/01','YYYY/MM/DD')),'DD') AS MONTH_DAYS_NUMBER FROM DUAL5.查询当前的⽇期格式SELECT TO_CHAR(SYSDATE,'YYYY/MM/DD') AS MONTH FROM DUAL--获取当前⽇期的'YYYY/MM/DD'格式:2020/01/02SELECT TO_CHAR(SYSDATE,'YYYYMMDD') AS MONTH FROM DUAL--获取当前⽇期的'YYYYMMDD'格式:20200102SELECT TO_CHAR(SYSDATE,'YYYYMMDD HH:MI:SS') AS now FROM DUAL--获取当前时间,精确到秒的12⼩时制格式:20200102 03:18:25SELECT TO_CHAR(SYSDATE,'YYYYMMDD HH24:MI:SS') AS now FROM DUAL--获取当前时间,精确到秒24⼩时制的格式:20200102 15:18:13SELECT TO_CHAR(SYSDATE,'YYYY/MM/DD HH24:MI:SS:PM:DY') AS now FROM DUAL--获取当前时间的格式,显⽰上、下午和星期⼏:2020/01/02 15:17:59:下午:星期四6.查询距离当前时间⼀段时间间隔的时间,当前时间之前⽤“-”当前时间之后⽤“+”SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7' second,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7秒前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7' minute,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7分钟前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'hour ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7⼩时前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'day ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7天前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'month ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7⽉前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE - INTERVAL '7'year ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间的7年前时间SELECT TO_CHAR(SYSDATE, 'YYYY/MM/DD HH24:MI:SS') AS NOW,TO_CHAR(SYSDATE -8*INTERVAL '7'hour ,'YYYY/MM/DD HH24:MI:SS') AS PAST FROM DUAL --查询当前时间参数年、⽉、⽇、时、分、秒乘以⼀个数字倍数之前的时。

SQL日期格式大全

SQL日期格式大全

SQL 日期格式大全在函数CONVERT()中你可以使用许多种不同风格的日期和时间格式。

0 Default mon dd yyyy hh:miAM1 USA mm/dd/yy2 ANSI yy.mm.dd3 British/French dd/mm/yy4 German dd.mm.yy5 Italian dd-mm-yy6 - dd mon yy7 - mon dd,yy8 - hh:mi:ss9 Default + milliseconds--mon dd yyyyhh:mi:ss:mmmAM(or )10 USA mm-dd-yy11 JAPAN yy/mm/dd12 ISO yymmdd13 Europe Default + milliseconds--dd mon yyyyhh:mi:ss:mmm(24h)14 - hh:mi:ss:mmm(24h)类型0,9,和13总是返回四位的年。

对其它类型,要显示世纪,把style值加上100。

类型13和14返回24小时时钟的时间。

类型0,7,和13返回的月份用三位字符表示(用Nov代表November)。

对表11.1中所列的每一种格式,你可以把类型值加上100来显示有世纪的年(例如,00年将显示为2000年)。

例如,要按日本标准显示日期,包括世纪,你应使用如下的语句:SELECT CONVERT(VARCHAR(30),GETDATE(),111)在这个例子中,函数CONVERT()把日期格式进行转换,显示为2001/11/30网友跟贴:1.日期格式样式,借以将datetime 或smalldatetime 数据转换为字符数据(nchar、nvarchar、char、varchar、nchar 或nvarchar 数据类型);或者字符串格式样式,借以将float、real、money 或s mallmoney 数据转换为字符数据(nchar、nvarchar、char、varchar、nchar 或nvarchar 数据类型)。

OracleSQL日期及日期格式获取命令

OracleSQL日期及日期格式获取命令

OracleSQL⽇期及⽇期格式获取命令⽇期及⽇期格式:获取⽇期:sysdate()格式化⽇期to_char(sysdate(),'yyyy-mm-dd,hh24:mi:ss')to_date(sysdate(),'yyyy-mm-dd,hh24:mi:ss')注:to_char 把⽇期或数字转换为字符串to_char(number, '格式')to_char(salary, '$99,999.99')to_char(date, '格式')to_date 把字符串转换为中的⽇期类型to_date(char, '格式')转换格式:表⽰ year 的:y 表⽰年的最后⼀位yy 表⽰年的最后2位yyy 表⽰年的最后3位yyyy ⽤4位数表⽰年表⽰ month 的:mm ⽤2位数字表⽰⽉mon ⽤简写形式,⽐如11⽉或者novmonth ⽤全称,⽐如11⽉或者november表⽰ day 的:dd 表⽰当⽉第⼏天ddd 表⽰当年第⼏天dy 当周第⼏天,简写,⽐如星期五或者friday 当周第⼏天,全称,⽐如星期五或者friday表⽰ hour 的:hh 2位数表⽰⼩时 12进制hh24 2位数表⽰⼩时 24⼩时表⽰minute的:mi 2位数表⽰分钟表⽰second的:ss 2位数表⽰秒 60进制表⽰季度的:q ⼀位数表⽰季度(1-4)另外还有ww ⽤来表⽰当年第⼏周 w⽤来表⽰当⽉第⼏周。

24⼩时制下的时间范围:00:00:00-23:59:5912⼩时制下的时间范围:1:00:00-12:59:59例⼦:返回系统⽇期: 2018/1/19 22:44:54select sysdate from dual;格式化: 2018-01-19 22:46:59select to_char(sysdate,'yy-mm-dd hh24:mi:ss') from dual获取昨天:2018/1/18select trunc(sysdate-1) from dual;获取上个⽉第⼀天:2017/12/1select add_months(trunc(sysdate,'MON'),-1) from dualselect add_months(trunc(sysdate,'MON'),-13) from dual获得本季度第⼀天:2018/1/1select trunc(add_months(sysdate,0),'Q') from dual获得上季度第⼀天:2017/10/1select trunc(add_months(sysdate,-3),'Q') from dual补充当前时间减去7分钟的时间select sysdate,sysdate - interval '7' MINUTE from dual;当前时间减去7⼩时的时间select sysdate - interval '7' hour from dual;当前时间减去7天的时间select sysdate - interval '7'day from dual;当前时间减去7⽉的时间select sysdate,sysdate - interval '7'month from dual;当前时间减去7年的时间select sysdate,sysdate - interval '7'year from dual;时间间隔乘以⼀个数字select sysdate,sysdate -8*interval '7' hour from dual;Oracle 常⽤的时间函数Sysdate :当前⽇期和时间SQL>Select sysdate from dual;2018/1/1923:15:20Last_day :本⽉最后⼀天SQL>Select last_day(sysdate) from dual;2018/1/3123:16:24Add_months(d,n) :当前⽇期d后推n个⽉,⽤于从⼀个⽇期值增加或减少⼀些⽉份SQL>Select add_months(sysdate,2) from dual;2018/3/1923:18:29Months_between(f,s) :⽇期f和s间相差⽉数SQL>select months_between(sysdate,to_date('2017-8-1','yyyy-mm-dd'))from dual;5.6120034348865NEXTDAY(d, dayofweek) :返回由"dayofweek"命名的,在变量"d"指定的⽇期之后的第⼀个⼯作⽇的⽇期。

SQL设置时间格式

SQL设置时间格式

SQL设置时间格式SELECT STR_TO_DATE('Jul 20 2013 7:49:14:610AM','%b %d %Y %h:%i:%s:%f%p') from DUAL; -- 执⾏后得到结果:'2013-07-20 07:49:14.610000'另外还有int值和时间变量相互转化的情况:SELECT UNIX_TIMESTAMP(2009-4-5 12:50:58) RROM DUAL;-- 结果为:1238907058SELECT FROM_UNIXTIME(1238907058) FROM DUAL;-- 结果为:'2009-4-5 12:50:58'还可以⾃定义输出格式:SELECT FROM_UNIXTIME( 1234567890, '%Y-%m-%d %H:%i:%S' ) FROM DUAL;--结果为:'2009-02-14 07:31:30'具体格式符号如下:%W 星期名字(Sunday……Saturday)%D 有英语前缀的⽉份的⽇期(1st, 2nd, 3rd, 等等。

)%Y 年, 数字, 4 位%y 年, 数字, 2 位%a 缩写的星期名字(Sun……Sat)%d ⽉份中的天数, 数字(00……31)%e ⽉份中的天数, 数字(0……31)%m ⽉, 数字(01……12)%c ⽉, 数字(1……12)%b 缩写的⽉份名字(Jan……Dec)%j ⼀年中的天数(001……366)%H ⼩时(00……23)%k ⼩时(0……23)%h ⼩时(01……12)%I ⼩时(01……12)%l ⼩时(1……12)%i 分钟, 数字(00……59)%r 时间,12 ⼩时(hh:mm:ss [AP]M)%T 时间,24 ⼩时(hh:mm:ss)%S 秒(00……59)%s 秒(00……59)%f 毫秒(000...999)%p AM或PM%w ⼀个星期中的天数(0=Sunday ……6=Saturday )%U 星期(0……52), 这⾥星期天是星期的第⼀天%u 星期(0……52), 这⾥星期⼀是星期的第⼀天%% ⼀个⽂字“%”。

sqlserver中2011-10-01格式转化为20111001

sqlserver中2011-10-01格式转化为20111001

sqlserver中2011-10-01格式转化为20111001
这句话的意思是,在SQL Server 中,将日期格式"2011-10-01" 转换为"20111001" 的形式。

具体来说,它将日期格式从"YYYY-MM-DD" 转换为"YYYYMMDD"。

在 SQL Server 中,可以使用CONVERT函数和FORMAT函数来转换日期的格式。

下面是两种将日期格式从 "YYYY-MM-DD" 转换为 "YYYYMMDD" 的方法:
1.使用CONVERT函数:
SELECT CONVERT(VARCHAR, '2011-10-01', 112) AS ConvertedDate;
这将返回结果 "20111001"。

2. 使用FORMAT函数:
SELECT FORMAT('2011-10-01', 'yyyyMMdd') AS FormattedDate;
这将返回结果 "20111001"。

总结来说,"sqlserver中2011-10-01格式转化为20111001" 的具体内容是指将日期格式从"YYYY-MM-DD" 转换为"YYYYMMDD",可以使用CONVERT函数或FORMAT函数来实现。

sql日期格式

sql日期格式

关键字: sqlserver 日期, 字符串格式转换SELECT convert(char,你的日期字段,120) as date2 FROM table mssql默认以系统时间格式输出,你可以调整系统的时间格式来解决当然是在程序里解决比较灵活,convert(char,date,N)输出的各中样式N 日期样式0 04 2 2005 9:06AM1 04/02/052 05.04.023 02/04/054 02.04.055 02-04-056 02 04 057 04 02, 058 09:06:189 04 2 2005 9:06:18:857AM10 04-02-0511 05/04/0212 05040213 02 04 2005 09:06:18:85714 09:06:18:85720 2005-04-02 09:06:1821 2005-04-02 09:06:18.85722 04/02/05 9:06:18 AM23 2005-04-0224 09:06:1825 2005-04-02 09:06:18.857100 04 2 2005 9:06AM101 04/02/2005102 2005.04.02103 02/04/2005104 02.04.2005105 02-04-2005106 02 04 2005107 04 02, 2005108 09:06:18109 04 2 2005 9:06:18:857AM110 04-02-2005111 2005/04/02112 20050402113 02 04 2005 09:06:18:857114 09:06:18:857120 2005-04-02 09:06:18121 2005-04-02 09:06:18.857126 2005-04-02T09:06:18.857sql to_char 日期转换字符串2009-04-27 12:241、转换函数与date操作关系最大的就是两个转换函数:to_date(),to_char()to_date() 作用将字符类型按一定格式转化为日期类型:具体用法:to_date('2004-11-27','yyyy-mm-dd'),前者为字符串,后者为转换日期格式,注意,前后两者要以一对应。

sql年月日时分秒格式写法

sql年月日时分秒格式写法

在SQL 中,可以使用不同的格式来存储日期和时间。

以下是一些常用的日期和时间格式:
1. 格式化日期:
```sql
SELECT DATE_FORMAT(date_column, '%Y-%m-%d') AS formatted_date FROM table_name;
```
这将返回一个格式为'YYYY-MM-DD' 的日期字符串。

2. 格式化时间:
```sql
SELECT DATE_FORMAT(time_column, '%H:%i:%s') AS formatted_time FROM table_name;
```
这将返回一个格式为'HH:MI:SS' 的时间字符串。

3. 格式化日期和时间:
```sql
SELECT DATE_FORMAT(datetime_column, '%Y-%m-%d %H:%i:%s') AS formatted_datetime FROM table_name;
```
这将返回一个格式为'YYYY-MM-DD HH:MI:SS' 的日期时间字符串。

其中,`date_column`、`time_column` 和`datetime_column` 是存储日期、时间和日期时间的列名,`table_name` 是包含这些列的表名。

在格式字符串中,`%Y` 表示四位数的年份,`%m` 表示两位数的月份,`%d` 表示两位数的日期,`%H` 表示两位数的小时数,`%i` 表示两位数的分钟数,`%s` 表示两位数的秒数。

sql日期时间格式转换

sql日期时间格式转换
博客园 用户登录 代码改变世界 密码登录 短信登录 忘记登录用户名 忘记密码 记住我 登录 第三方登录/注册 没有账户, 立即注册
sql日 期 时 间 格 式 转 换
1. Select CONVERT(varchar(100), GETDATE(), 0): 05 16 2006 10:57AM 2. Select CONVERT(varchar(100), GETDATE(), 1): 05/16/06 3. Select CONVERT(varchar(100), GETDATE(), 2): 06.05.16 4. Select CONVERT(varchar(100), GETDATE(), 3): 16/05/06 5. Select CONVERT(varchar(100), GETDATE(), 4): 16.05.06 6. Select CONVERT(varchar(100), GETDATE(), 5): 16-05-06 7. Select CONVERT(varchar(100), GETDATE(), 6): 16 05 06 8. Select CONVERT(varchar(100), GETDATE(), 7): 05 16, 06 9. Select CONVERT(varchar(100), GETDATE(), 8): 10:57:46 10. Select CONVERT(varchar(100), GETDATE(), 9): 05 16 2006 10:57:46:827AM 11. Select CONVERT(varchar(100), GETDATE(), 10): 05-16-06 12. Select CONVERT(varchar(100), GETDATE(), 11): 06/05/16 13. Select CON
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

关键字: sqlserver 日期, 字符串格式转换SELECT convert(char,你的日期字段,120) as date2 FROM table mssql默认以系统时间格式输出,你可以调整系统的时间格式来解决当然是在程序里解决比较灵活,convert(char,date,N)输出的各中样式N 日期样式0 04 2 2005 9:06AM1 04/02/052 05.04.023 02/04/054 02.04.055 02-04-056 02 04 057 04 02, 058 09:06:189 04 2 2005 9:06:18:857AM10 04-02-0511 05/04/0212 05040213 02 04 2005 09:06:18:85714 09:06:18:85720 2005-04-02 09:06:1821 2005-04-02 09:06:18.85722 04/02/05 9:06:18 AM23 2005-04-0224 09:06:1825 2005-04-02 09:06:18.857100 04 2 2005 9:06AM101 04/02/2005102 2005.04.02103 02/04/2005104 02.04.2005105 02-04-2005106 02 04 2005107 04 02, 2005108 09:06:18109 04 2 2005 9:06:18:857AM110 04-02-2005111 2005/04/02112 20050402113 02 04 2005 09:06:18:857114 09:06:18:857120 2005-04-02 09:06:18121 2005-04-02 09:06:18.857126 2005-04-02T09:06:18.857sql to_char 日期转换字符串2009-04-27 12:241、转换函数与date操作关系最大的就是两个转换函数:to_date(),to_char()to_date() 作用将字符类型按一定格式转化为日期类型:具体用法:to_date('2004-11-27','yyyy-mm-dd'),前者为字符串,后者为转换日期格式,注意,前后两者要以一对应。

如;to_date('2004-11-27 13:34:43', 'yyyy-mm-dd hh24:mi:ss') 将得到具体的时间多种日期格式:YYYY:四位表示的年份YYY,YY,Y:年份的最后三位、两位或一位,缺省为当前世纪MM:01~12的月份编号MONTH:九个字符表示的月份,右边用空格填补MON:三位字符的月份缩写WW:一年中的星期D:星期中的第几天DD:月份中的第几天DDD:年所中的第几天DAY:九个字符表示的天的全称,右边用空格补齐HH,HH12:一天中的第几个小时,12进制表示法HH24:一天中的第几个小时,取值为00~23MI:一小时中的分钟SS:一分钟中的秒SSSS:从午夜开始过去的秒数to_char():将日期转按一定格式换成字符类型SQL> select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') time from dual;TIME-------------------2004-10-08 15:22:58即把当前时间按yyyy-mm-dd hh24:mi:ss格式转换成字符类型在oracle中处理日期大全TO_DATE格式Day:dd number 12dy abbreviated friday spelled out fridayddspth spelled out, ordinal twelfthMonth:mm number 03mon abbreviated marmonth spelled out marchYear:yy two digits 98yyyy four digits 199824小时格式下时间范围为: 0:00:00 - 23:59:59....12小时格式下时间范围为: 1:00:00 - 12:59:59 ....[ZT]日期和時間函數匯總1.日期和字符转换函数用法(to_date,to_char)2.select to_char( to_date(222,'J'),'Jsp') from dual显示Two Hundred Twenty-Two3.求某天是星期几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 table1UNIONselect 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 = Americanalter 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_parametersselect * from V$NLS_PARAMETERS8.select count(*)from ( select rownum-1 rnumfrom all_objectswhere 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' )notin ( '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;1select months_between(to_date('02-01-1999','MM-DD-YYYY'),to_date('12-31-1998','MM-DD-YYYY')) "MONTHS" FROM DUAL;1.0322580645161310. Next_day的用法Next_day(date, day)Monday-Sunday, for format code DAYMon-Sun, for format code DY1-7, for format code D11select to_char(sysdate,'hh:mi:ss') TIME from all_objects注意:第一条记录的TIME 与最后一行是一样的可以建立一个函数来处理这个问题create or replace function sys_date return date isbeginreturn sysdate;end;select to_char(sys_date,'hh:mi:ss') from all_objects;12.获得小时数SELECT EXTRACT(HOUR FROM TIMESTAMP '2001-02-16 2:38:40') from offerSQL> select sysdate ,to_char(sysdate,'hh') from dual;SYSDATE TO_CHAR(SYSDATE,'HH')-------------------- ---------------------2003-10-13 19:35:21 07SQL> 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 ))) daysfrom ( selecttrunc(months_between( newer_date, older_date )/12) YEARS,mod(trunc(months_between( newer_date, older_date )),12 ) MONTHS,newer_date,older_datefrom ( select hiredate older_date,add_months(hiredate,rownum)+rownum newer_datefrom emp ))14.处理月份天数不定的办法select to_char(add_months(last_day(sysdate) +1, -2), 'yyyymmdd'),last_day(sysdate) from dual16.找出今年的天数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 0099rrrr 99 1999yyyy 01 0001rrrr 01 200118.不同时区的处理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 dual2002-11-1 9:55:00 35786SSSSS表示5位秒数20.一年的第几天select TO_CHAR(SYSDATE,'DDD'),sysdate from dual310 2002-11-6 10:03:5121.计算小时,分,秒,毫秒selectDays,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)) mSecondsfrom(selecttrunc(sysdate) Days,sysdate - trunc(sysdate) Afrom dual)select * from tabnameorder by decode(mode,'FIFO',1,-1)*to_char(rq,'yyyymmddhh24miss');//floor((date2-date1) /365) 作为年floor((date2-date1, 365) /30) 作为月mod(mod(date2-date1, 365), 30)作为日.23.next_day函数next_day(sysdate,6)是从当前开始下一个星期五。

相关文档
最新文档