sql 日期时间函数+格式转换



sql 日期时间函数+格式转换

文章插图
转换函数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;
1、常用日期方法(1)DATENAME ( datepart ,date )返回表示指定日期的指定日期部分的字符串 。SELECT DateName(day,Getdate()) –返回1
(2)DATEPART ( datepart , date )返回表示指定日期的指定日期部分的整数 。SELECT DATEPART(year,Getdate()) –返回2016
(3)DATEADD (datepart , number, date )返回给指定日期加上一个时间间隔后的新datetime 值 。SELECT DATEADD(week,1,GetDate()) –当前日期加一周后的日期
(4)DATEDIFF ( datepart , startdate , enddate )返回跨两个指定日期的日期边界数和时间边界数 。SELECT DATEDIFF(month,’2006-10-11’,’2006-11-01’) –返回1
(5)DAY ( date )返回一个整数 。表示指定日期的天datepart 部分 。SELECT day(GetDate()) –返回1
(6)GETDATE()以datetime值的SQL Server 2005 标准内部格式返回当前系统日期和时间 。SELECT GetDate() –返回2016-04-01 20:37:56.233
(7)MONTH ( date )返回表示指定日期的“月”部分的整数 。SELECT MONTH(GETDATE()) –返回11
(8)YEAR ( date )返回表示指定日期的“年”部分的整数 。SELECT YEAR(GETDATE()) –返回2016
2、取特定日期(1)获得当前日期是星期几SELECT DateName(weekday,Getdate()) –星期五
(2)计算哪一天是本周的星期一SELECT DATEADD(week, DATEDIFF(week,’1900-01-01’,getdate()), ‘1900-01-01’)SELECT DATEADD(week, DATEDIFF(week,0,getdate()),0)
(3)当前季度的第一天SELECT DATEADD(quarter, DATEDIFF(quarter,0,getdate()), 0)
(4)如何取得某个月的天数SELECT Day(dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,’2006-02-03’)+1,0)))
(5)一个季度多少天
declare @m tinyint,@time smalldatetime
select @m=month(getdate())select @m=case when @m between 1 and 3 then 1when @m between 4 and 6 then 4when @m between 7 and 9 then 7else 10 end
select @time=datename(year,getdate())+’-‘+convert(varchar(10),@m)+’-01’select datediff(day,@time,dateadd(mm,3,@time))
【sql 日期时间函数+格式转换】(6)获得年月日(yyyy-MM-dd)
SELECT CONVERT(VARCHAR(10),GETDATE(),120)
3、其它
(1)–下面的示例将日期指定为数字 。数据库引擎将0 解释为1900 年1 月1 日 。SELECT MONTH(0), DAY(0), YEAR(0)–下面两句是等效的SELECT DATENAME(WEEKDAY,0)SELECT DATENAME(WEEKDAY,’1900-01-01’)
(2)SET DATEFIRST { number | @number_var }将一周的第一天设置为从1 到7 的一个数字 。
SET DATEFIRST 1 –表示一周的第一天是“星期一”SELECT DATENAME(WEEKDAY,GETDATE())SELECT DATEPART(weekday,GETDATE())–查看当前设置情况select @@DATEFIRST(3)SET DATEFORMAT { format | @format_var }
设置用于输入datetime 或smalldatetime 数据的日期部分(月/日/年)的顺序 。…有效参数包括mdy、dmy、ymd、ydm、myd 和dym 。…该设置仅用在将字符串转换为日期值时的解释中 。它不影响日期值的显示 。…SET DATEFORMAT 的设置是在执行或运行时设置 。而不是在分析时设置 。…SET DATEFORMAT 将覆盖SET LANGUAGE 的隐式日期格式设置 。下面是例子:– Set date format to year, day, month.SET DATEFORMAT ydm;GODECLARE @datevar DATETIME;SET @datevar = ‘1998/31/12’;SELECT @datevar AS DateVar;GO– Set date format to year, month, day.SET DATEFORMAT ymd;GODECLARE @datevar DATETIME;SET @datevar = ‘1998/12/31’;SELECT @datevar AS DateVar;GO
(4)日期部分的列表
日期部分
缩写
year
yy, yyyy
quarter
qq, q
month
mm, m
dayofyear
dy, y
day
dd, d
week
wk, ww
weekday
dw
hour
hh
minute
mi, n
second
ss, s
millisecond
ms
数据类型
范围
精确度
datetime
1753 年 1 月 1 日到 9999 年 12 月 31 日3.33 毫秒

推荐阅读