【澳门金沙vip】SQL SERVER 数据库日期算法总结

复制代码 代码如下:DECLARE @LocalDate
DATETIME, @UTCDate DATETIME, @LocalDate2 DATETIME SET @LocalDate =
GETDATE() SET @UTCDate = DATEADD(hour,
DATEDIFF(hour,GETDATE(),GETUTCDATE()), @LocalDate) SET @LocalDate2 =
DATEADD(hour, DATEDIFF(hour,GETUTCDATE(),GETDATE()), @UTCDate) SELECT
‘1. Now’ [Now], @LocalDate [DateTime] UNION SELECT ‘2. UTC’,
@UTCDate UNION SELECT ‘3. Now again’, @LocalDate2

DECLARE @Date  DATETIME
SET @Date=GETDATE()
–前一天,给定日期的前一天
SELECT DATEADD(DAY,-1,@Date) AS ‘前一天’
–后一天,给定日期的后一天
SELECT DATEADD(DAY,1,@Date) AS ‘后一天’
GO

1、常用日期方法(下面的GetDate() = ‘2006-11-08 13:37:56.233’)

–月初,计算给定日期所在月的第一天
–这个计算的技巧是先计算当前日期到”1900-01-01″的时间间隔数,然后把它加到”1900-01-01″上来获得特殊的日期
–这个技巧可以用来计算很多不同的日期
DECLARE @Date  DATETIME
SET @Date=GETDATE()
SELECT DATEADD(MONTH,DATEDIFF(MONTH,’1900-01-01′,@Date),’1900-01-01′) AS ‘所在月的第一天’
–精简算法,根据SQL
Server的时间表示方式可知,’1900-01-01′ 可以用0代替
SELECT DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0) AS ‘所在月的第一天’
–上面两种算法精确到天时分秒均为00:00:00.000
–下面算法课以保留时分秒
–思路:用给定日期减去月第一天与给定日期差的天数
SELECT DATEADD(DAY,1-DATEPART(DAY,@Date),@Date)
GO

(1)DATENAME ( datepart ,date )

–月末,计算给定日期所在月的最后一天
DECLARE @Date  DATETIME
SET @Date=GETDATE()
–思路:当前月的下一月1号在减1天
SELECT DATEADD(DAY,-1,DATEADD(MONTH,1+DATEDIFF(MONTH,’1900-01-01′,@Date),’1900-01-01′)) AS ‘所在月的最一天’
SELECT DATEADD(MONTH,1+DATEDIFF(MONTH,’1900-01-01′,@Date),’1900-01-01′)-1
AS ‘所在月的最一天’
–1900-01-01 用0代替
SELECT DATEADD(DAY,-1,DATEADD(MONTH,1+DATEDIFF(MONTH,0,@Date),0)) AS ‘所在月的最一天’
SELECT DATEADD(MONTH,1+DATEDIFF(MONTH,0,@Date),0)-1
AS ‘所在月的最一天’
–思路:与月初计算思路相同
SELECT DATEADD(MONTH,DATEDIFF(MONTH,’1989-12-31′,@Date),’1989-12-31′) AS ‘所在月的最一天’
–精简算法,’1989-12-31′ 用-1代替
SELECT DATEADD(MONTH,DATEDIFF(MONTH,-1,@Date),-1)
AS ‘所在月的最一天’
–保留时分秒的算法
SELECT DATEADD(DAY,-1,DATEADD(MONTH,1,DATEADD(DAY,1-DATEPART(DAY,@Date),@Date)))
GO

   返回表示指定日期的指定日期部分的字符串。Datepart详见下面的列表.

–其他月计算
–计算给定日期所在月的上月第一天
DECLARE @Date  DATETIME
SET @Date=GETDATE()
–当前月第一天减去一个月
SELECT DATEADD(MONTH,-1,DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0)) AS ‘上月第一天’
–简化
SELECT DATEADD(MONTH,DATEDIFF(MONTH,0,@Date)-1,0)
AS ‘上月第一天’
–另一种当前月第一天算法
SELECT DATEADD(MONTH,-1,DATEADD(DAY,1-DATEPART(DAY,@Date),@Date)) ‘上月第一天’
GO

SELECT DateName(day,Getdate()) –返回8

–计算给定日期所在月的上月最后一天
DECLARE @Date  DATETIME
SET @Date=GETDATE()
–当前月第一天减去一天
SELECT DATEADD(DAY,-1,DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0)) AS ‘上月最后一天’
–另一种当前月第一天算法
SELECT DATEADD(DAY,-1,DATEADD(DAY,1-DATEPART(DAY,@Date),@Date)) ‘上月最后一天’
SELECT DATEADD(DAY,1-DATEPART(DAY,@Date),@Date)-1
‘上月最后一天’
–另一种算法,不能用当前月的最后一天加一个月,因为当前月可能是30天。
–例如 SELECT
DATEADD(MONTH,1,’2010-06-30′)
–结果是2010-07-30而不是2010-07-31,
–这也是月末算法采用下月第一天减1天计算的原因
–但是如果计算月是31天择无此问题
–例如 SELECT
DATEADD(MONTH,1,’2010-05-31′) –结果是2010-06-30
–因此下面算法是正确的,-1 表示’1899-12-31
00:00:00.000′– SELECT CONVERT(DATETIME,-1)
SELECT DATEADD(MONTH,DATEDIFF(MONTH,-1,@Date)-1,-1)
–另一种当前月算法
SELECT DATEADD(DAY,-1,DATEADD(DAY,1-DATEPART(DAY,@Date),@Date)) ‘上月最后一天’
–简化
SELECT DATEADD(DAY,0-DATEPART(DAY,@Date),@Date) ‘上月最后一天’
GO

(2)DATEPART ( datepart , date )

–计算给定日期所在月的下月第一天
DECLARE @Date  DATETIME
SET @Date=GETDATE()
–当前月第一天加一个月
SELECT DATEADD(MONTH,1,DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0)) AS ‘下月第一天’
–简化
SELECT DATEADD(MONTH,DATEDIFF(MONTH,0,@Date)+1,0)
AS ‘下月第一天’
–另一种当前月第一天算法
SELECT DATEADD(MONTH,1,DATEADD(DAY,1-DATEPART(DAY,@Date),@Date)) ‘下月第一天’
GO

    返回表示指定日期的指定日期部分的整数。

–计算给定日期所在月的下月最后一天
DECLARE @Date  DATETIME
SET @Date=GETDATE()
–当前月第一天加2个月再减去1天
SELECT DATEADD(DAY,-1,DATEADD(MONTH,2,DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0))) AS ‘下月最后一天’
–简化
SELECT DATEADD(DAY,-1,DATEADD(MONTH,DATEDIFF(MONTH,0,@Date)+2,0)) AS ‘下月最后一天’
SELECT DATEADD(MONTH,DATEDIFF(MONTH,0,@Date)+2,0)-1
AS ‘下月最后一天’
–另一种算法
SELECT DATEADD(MONTH,DATEDIFF(MONTH,-1,@Date)+1,-1)
‘下月最后一天’
–另一种当前月第一天算法
SELECT DATEADD(DAY,-1,DATEADD(MONTH,2,DATEADD(DAY,1-DATEPART(DAY,@Date),@Date))) ‘下月最后一天’
GO

SELECT DATEPART(year,Getdate()) –返回2006

–所在星期的第一天,计算给定日期所在星期的第1天(星期日为第一天)
DECLARE @Date  DATETIME
SET @Date= GETDATE()
–与SQL Server语言版本相关的算法
–思路:当前日期+星期日(每周的第1天)与当前日期的差的天数
–DATEPART(WEEKDAY,DATE)的返回值与@@DATEFIRST相关
SET DATEFIRST 7 —
或者设置为美国英语SET LANGUAGE us_english; (星期日为第一天)
SELECT DATEADD(WEEKDAY,1-DATEPART(WEEKDAY,@Date),@Date) AS ‘所在星期的第一天,星期日’
–星期日,与SQL
Server语言版本或@@DATEFIRST无关
–‘1989-12-31′ 是星期日,’1989-12-31’
再加上(当前日期与1989-12-31差的星期数)个星期
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,-1,@Date),-1)
AS ‘所在星期的星期日’
–或者
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,6,@Date),6) AS ‘所在星期的星期日’
GO

(3)DATEADD (datepart , number, date
)

–所在星期的第二天,计算给定日期所在星期的第2天(星期日为第一天)
DECLARE @Date  DATETIME
SET @Date= GETDATE()
–思路:当前日期+星期一(每周的第2天)与当前日期的差的天数
–DATEPART(WEEKDAY,DATE)的返回值与@@DATEFIRST相关
SET DATEFIRST 7 —
或者设置为美国英语SET LANGUAGE us_english; (星期日为第一天)
SELECT DATEADD(DAY,2-DATEPART(WEEKDAY,@Date),@Date) AS ‘所在星期的第二天,星期一’
–星期一,与SQL
Server语言版本或@@DATEFIRST无关
–‘1900-01-01′ 是星期一,’1900-01-01’
再加上(当前日期与1900-01-01差的星期数)个星期
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,0,@Date),0) AS ‘所在星期的星期一’
GO

    返回给指定日期加上一个时间间隔后的新datetime 值。

–上个星期第一天,计算给定日期所在星期的上一个星期日(星期日为第一天)
DECLARE @Date  DATETIME
SET @Date= GETDATE()
–思路:当前日志所在星期的星期日再减1周
–DATEPART(WEEKDAY,DATE)的返回值与@@DATEFIRST相关
SET DATEFIRST 7 —
或者设置为美国英语SET LANGUAGE us_english; (星期日为第一天)
SELECT DATEADD(WEEK,-1,DATEADD(DAY,1-DATEPART(WEEKDAY,@Date),@Date)) AS ‘上个星期第一天,星期日’
–一周等于7天
SELECT DATEADD(DAY,-7,DATEADD(DAY,1-DATEPART(WEEKDAY,@Date),@Date)) AS ‘上个星期第一天,星期日’
–简化
SELECT DATEADD(DAY,-6-DATEPART(WEEKDAY,@Date),@Date) AS ‘上个星期第一天,星期日’
–上个星期日,与SQL
Server语言版本或@@DATEFIRST无关
SELECT DATEADD(WEEK,-1+DATEDIFF(WEEK,-1,@Date),-1)
AS ‘上个星期日’
–或者
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,6,@Date),-1)
AS ‘上个星期日’
GO

SELECT DATEADD(week,1,GetDate()) –当前日期加一周后的日期

–下个星期第一天,计算给定日期所在星期的下一个星期日(星期日为第一天)
DECLARE @Date  DATETIME
SET @Date= GETDATE()
–思路:当前日志所在星期的星期日再加1周
–DATEPART(WEEKDAY,DATE)的返回值与@@DATEFIRST相关
SET DATEFIRST 7 —
或者设置为美国英语SET LANGUAGE us_english; (星期日为第一天)
SELECT DATEADD(WEEK,1,DATEADD(DAY,1-DATEPART(WEEKDAY,@Date),@Date)) AS ‘下个星期第一天,星期日’
–一周等于7天
SELECT DATEADD(DAY,7,DATEADD(DAY,1-DATEPART(WEEKDAY,@Date),@Date)) AS ‘下个星期第一天,星期日’
–简化
SELECT DATEADD(DAY,8-DATEPART(WEEKDAY,@Date),@Date) AS ‘下个星期第一天,星期日’
–下个星期日,与SQL
Server语言版本或@@DATEFIRST无关
SELECT DATEADD(WEEK,1+DATEDIFF(WEEK,-1,@Date),-1)
AS ‘下个星期日’
–或者
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,-1,@Date),6) AS ‘下个星期日’
GO

(4)DATEDIFF ( datepart , startdate
, enddate )

–判断给定日期是星期几
DECLARE @Date  DATETIME
SET @Date= GETDATE()
–DATEPART(WEEKDAY,DATE)的返回值与@@DATEFIRST相关
SET DATEFIRST 7 —
或者设置为美国英语SET LANGUAGE us_english; (星期日为第一天)
SELECT DATEPART(WEEKDAY,@Date) –返回值
1-星期日,2-星期一,3-星期二……7-星期六
–上面算法与SQL 语言版本或 @@DATEFIRST
相关
–下面算法与SQL
Server语言版本或@@DATEFIRST无关
SELECT DATENAME(WEEKDAY,@Date) ‘星期’
GO

返回跨两个指定日期的日期边界数和时间边界数。

–年度计算
DECLARE @Date  DATETIME
SET @Date=GETDATE()
–年初,计算给定日期所在年的第一天
SELECT DATEADD(YEAR,DATEDIFF(YEAR,0,@Date),0) AS ‘所在年的第一天’
–年末,计算给定日期所在年的最后一天
SELECT DATEADD(YEAR,DATEDIFF(YEAR,-1,@Date),-1)
AS ‘所在年的最后一天’
–上一年年初,计算给定日期所在年的上一年的第一天
SELECT DATEADD(YEAR,DATEDIFF(YEAR,-0,@Date)-1,0)
AS ‘所在年的上一年的第一天’
–上一年年末,计算给定日期所在年的上一年的最后一天
SELECT DATEADD(YEAR,DATEDIFF(YEAR,0,@Date),-1)
AS ‘所在年的上一年的最后一天’
–下一年年初,计算给定日期所在年的下一年的第一天
SELECT DATEADD(YEAR,1+DATEDIFF(YEAR,0,@Date),0) AS ‘所在年的下一年的第一天’
–下一年年末,计算给定日期所在年的下一年的最后一天
SELECT DATEADD(YEAR,1+DATEDIFF(YEAR,-1,@Date),-1)
AS ‘所在年的下一年的最后一天’
GO

SELECT DATEDIFF(month,’2006-10-11′,’2006-11-01′) –返回1

–季度计算
DECLARE @Date  DATETIME
SET @Date=GETDATE()
–季度初,计算给定日期所在季度的第一天
SELECT
DATEADD(QUARTER,DATEDIFF(QUARTER,0,@Date),0) AS ‘当前季度的第一天’
–季度末,计算给定日期所在季度的最后一天
SELECT DATEADD(QUARTER,1+DATEDIFF(QUARTER,0,@Date),-1)
AS ‘当前季度的最后一天’
–上个季度初
SELECT
DATEADD(QUARTER,DATEDIFF(QUARTER,0,@Date)-1,0)
AS ‘当前季度的上个季度初’
–上个季度末
SELECT
DATEADD(QUARTER,DATEDIFF(QUARTER,0,@Date),-1)
AS ‘当前季度的上个季度末’
–下个季度初
SELECT DATEADD(QUARTER,1+DATEDIFF(QUARTER,0,@Date),0) AS ‘当前季度的下个季度初’
–下个季度末
SELECT DATEADD(QUARTER,2+DATEDIFF(QUARTER,0,@Date),-1)
AS ‘当前季度的下个季度末’
GO
–计算给定日期所在月的天数
DECLARE @Date DATETIME; 
SET @Date = GETDATE()
–本月度第一天与下月度第一天所差的天数
SELECT DATEDIFF(DAY,DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0),DATEADD(MONTH,1+DATEDIFF(MONTH,0,@Date),0))
–借助变量简化
SELECT @Date = DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0)
–本月度第一天
SELECT DATEDIFF(DAY,@Date,DATEADD(MONTH,1,@Date))
–另一种思路:给定月最后一天的日期,记为本月天数
SELECT DAY(DATEADD(MONTH,DATEDIFF(MONTH,-1,@Date),-1))
GO
–计算给定日期所在季度的天数
DECLARE @Date DATETIME; SET @Date = GETDATE()
–本季度第一天与下季度第一天所差的天数
SELECT DATEDIFF(DAY,DATEADD(QUARTER,DATEDIFF(QUARTER,0,@Date),0),DATEADD(QUARTER,1+DATEDIFF(QUARTER,0,@Date),0))
–借助变量简化
SELECT @Date = DATEADD(QUARTER,DATEDIFF(QUARTER,0,@Date),0)
–本季度第一天
SELECT DATEDIFF(DAY,@Date,DATEADD(QUARTER,1,@Date))
GO
–计算给定日期所在年度的天数
DECLARE @Date DATETIME; SET @Date = GETDATE()
–本年度第一天与下年度第一天所差的天数
SELECT DATEDIFF(DAY,DATEADD(YEAR,DATEDIFF(YEAR,0,@Date),0),DATEADD(YEAR,1+DATEDIFF(YEAR,0,@Date),0))
–借助变量简化
SELECT @Date = DATEADD(YEAR,DATEDIFF(YEAR,0,@Date),0)
–本年度第一天
SELECT DATEDIFF(DAY,@Date,DATEADD(YEAR,1,@Date))
GO
–判断给定日期所在年是否闰年
–根据全年总天数判断
DECLARE @Date DATETIME
SET @Date = GETDATE()
SELECT
CASE DATEDIFF(DAY,DATEADD(YEAR,DATEDIFF(YEAR,0,@Date),0),DATEADD(YEAR,1+DATEDIFF(YEAR,0,@Date),0))
WHEN 365 THEN ‘平年’
ELSE ‘闰年’
END
–根据二月天数判断
–给日期的上一年最后一天加2个月,即为当年2月最后一天
SELECT
CASE DAY(DATEADD(MONTH,2,DATEADD(YEAR,DATEDIFF(YEAR,0,@Date),-1)))
WHEN 28 THEN ‘平年’
ELSE ‘闰年’
END
GO
–计算给定日期是当年的第几天
DECLARE @Date DATETIME; SET @Date = GETDATE()
SELECT
DATEPART(DAYOFYEAR,@Date)
[DayOfYear]
SELECT
DATENAME(DAYOFYEAR,@Date)
[DayOfYear]
–另一种思路:当前日期与上年最后一天差的天数
SELECT DATEDIFF(DAY,DATEADD(YEAR,DATEDIFF(YEAR,0,@Date),-1),@Date) [DayOfYear]
GO –计算给定日期是当年的第几周
DECLARE @Date DATETIME
SET @Date = GETDATE()
SELECT DATEPART(WEEK,@Date) [WeekOfYear]–返回int型
SELECT DATENAME(WEEK,@Date) [WeekOfYear]–返回varchar型
GO
–计算给定日期是当年的第几月
DECLARE @Date DATETIME
SET @Date = GETDATE() SELECT DATEPART(MONTH,@Date) [MonthOfYear]–返回int型
SELECT DATENAME(MONTH,@Date) [MonthOfYear] –返回varchar型
SELECT MONTH(@Date) [MonthOfYear] –返回int型
GO
–计算给定日期是当年的第几季度
DECLARE @Date DATETIME
SET @Date = GETDATE() SELECT DATEPART(QUARTER,@Date) [QuarterOfYear] –返回int型
SELECT DATENAME(QUARTER,@Date) [QuarterOfYear] –返回varchar型 
GO 
–计算给定日期是当月的第几周 
DECLARE @Date DATETIME
SET @Date = GETDATE() 
–思路,给定日期是当年的第几周-给定日期所在月第一天是当年的第几周 
SELECT DATEPART(WEEK,@Date)-DATEPART(WEEK,DATEADD(MONTH,DATEDIFF(MONTH,0,@Date),0))+1
[WeekOfMonth] 
SELECT DATEPART(WEEK,@Date)-DATEPART(WEEK,DATEADD(DAY,1-DATEPART(DAY,@Date),@Date))+1
[WeekOfMonth]
GO 
–计算给定日期所在月的第一个星期一是哪天 
DECLARE @Date DATETIME
SET @Date = GETDATE() 
–思路,1900-01-01(星期一)加上(给定日志所在月的月6号与1900-01-01差的周数)个周
–为什么不选7号?如果是7号,那么7好恰好是星期日的话,第一个周一就会算到8号。
–为什么不选5号?如果5号是星期六,那么周一就跑到上月了。小于5号与这个道理一样。
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,0,DATEADD(DAY,6-DATEPART(DAY,@Date),@Date)),0) ‘所在月的第一个星期一’ 
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,0,DATEADD(DAY,6-DATEPART(DAY,@Date),@Date)),7) ‘所在月的第二个星期一’ 
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,0,DATEADD(DAY,6-DATEPART(DAY,@Date),@Date)),1) ‘所在月的第一个星期二’ 
SELECT
DATEADD(WEEK,DATEDIFF(WEEK,0,DATEADD(DAY,6-DATEPART(DAY,@Date),@Date)),8) ‘所在月的第二个星期二’
GO

(5)DAY ( date )

返回一个整数,表示指定日期的天datepart 部分。

SELECT day(GetDate()) –返回8

(6)GETDATE()

以datetime 值的SQL Server 2005 标准内部格式返回当前系统日期和时间。