DATEDIFF 和 DATEADD

 1 /* 
 2   DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总数
 3   语法 DATEDIFF(interval, date1, date2[, firstdayofweek[, firstweekofyear]])
 4   interval 参数的设定值如下
 5   yyyy 年 
 6   q,qq 季 
 7   m,mm 月 
 8   y 一年的日数 
 9   d,dd 日 
10   w 一周的日数 
11   ww 周 
12   h 时 
13   n 分钟 
14   s 秒 
15   DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期
16   语法 DATEADD (datepart , number , date )
17   datepart 参数的设定值如下
18   year            yy,yyyy 年
19   quarter        qq,q    季度
20   month            mm,m    月
21   dayofyear        dy,y    一年的日数
22   day            dd,d    日
23   week            wk,ww   周
24   weekday        dw,w    周的日数
25   hour            hh      时
26   minute        mi,n    分
27   second        ss,s    秒
28   millisecond   ms        毫秒
29   microsecond    mcs        微妙
30   nanosecond    ns        纳秒          
31 
32   0相当于'1900-1-1'
33 
34   使用DATEDIFF和DATEADD函数来计算日期,和本来从当前日期转换到你需要的日期的考虑方法有点不同。
35   你必须从时间间隔这个方面来考虑。比如,从当前日期到你要得到的日期之间有多少时间间隔,
36   或者,从今天到某一天(比如1900-1-1)之间有多少时间间隔,等等。
37   理解怎样着眼于时间间隔有助于你轻松的理解我的不同的日期计算例子。 
38 */
39  --本月第一天
40  -- 我将告诉你如何从当前日期去这个月的最后一天。
41  -- 每一个例子都将通过计算当前的时间间隔,然后进行加减来得到想要计算的日期
42  
43  SELECT  DATEDIFF(mm, 0, GETDATE())
44  --本月第一天
45  --先看1900-1-1距离当前时间有n个月,然后在让1900-1-1加上n月则等于当月第一天
46  SELECT DATEADD(mm, DATEDIFF(mm, 0, GETDATE()), 0); 
47  --本周第一天
48  SELECT DATEADD(wk, DATEDIFF(wk, 0, GETDATE()), 0);  
49  --本年第一天
50  SELECT DATEADD(yy, DATEDIFF(yy, 0, GETDATE()), 0);  
51  --本季度第一天
52  SELECT DATEADD(qq, DATEDIFF(qq, 0, GETDATE()), 0);
53  --当天的半夜   
54  SELECT DATEADD(dd, DATEDIFF(dd, 0, GETDATE()), 0);  
55 --上个月的最后一天 
56 --它通过从一个月的最后一天这个例子上减去3毫秒来获得。有一点要记住,在SqlServer中时间是精确到3毫秒。这就是为什么我需要减去3毫秒来获得我要的日期和时间
57 SELECT DATEADD(ms, -3, DATEADD(mm, DATEDIFF(mm, 0, GETDATE()), 0)); 
58 --去年的最后一天 
59 SELECT DATEADD(ms, -3, DATEADD(yy, DATEDIFF(yy, 0, GETDATE()), 0));  
60 --本月的最后一天  
61 SELECT DATEADD(ms, -3, DATEADD(mm, DATEDIFF(m, 0, GETDATE()) + 1, 0));  
62 --本年的最后一天  
63 SELECT DATEADD(ms,-3, DATEADD(yy, DATEDIFF(yy, 0, GETDATE()) + 1, 0)); 
64 --本月的第一个星期一  
65 SELECT DATEADD(wk,DATEDIFF(wk, 0, DATEADD(dd, 6 - DATEPART(DAY, GETDATE()), GETDATE())), 0);     
 1 --今天的所有数据:
 2 SELECT * FROM [Table] WHERE DATEDIFF(dd, [datetime类型字段], GETDATE()) = 0;
 3                                                            
 4 --昨天的所有数据:                                           
 5 SELECT * FROM [Table] WHERE DATEDIFF(dd, [datetime类型字段], GETDATE()) = 1;
 6                                                            
 7 --7天内的所有数据:                                           
 8 SELECT * FROM [Table] WHERE DATEDIFF(dd, [datetime类型字段], GETDATE())< = 7;
 9                                                            
10 --30天内的所有数据:                                       
11 SELECT * FROM [Table] WHERE DATEDIFF(dd, [datetime类型字段], GETDATE())< = 30;
12                                                            
13 --本月的所有数据:                                           
14 SELECT * FROM [Table] WHERE DATEDIFF(mm, [datetime类型字段], GETDATE()) = 0;
15                                                            
16 --本年的所有数据:                                           
17 SELECT * FROM [Table] WHERE DATEDIFF(yy, [datetime类型字段], GETDATE()) = 0;
18 
19 
20 --查询今天是今年的第几天: 
21 SELECT DATEPART(DAYOFYEAR, GETDATE());
22 
23 --查询今天是本月的第几天:
24 --1. 
25 SELECT DATEPART(dd, GETDATE());  
26 --2.
27 SELECT DAY(GETDATE());
28 
29 --查询本周的星期一日期是多少 (注意:指定日期不能是周日,如果是周日会计算到下周一去。所以如果是周日要减一天)
30 SELECT DATEADD(wk, DATEDIFF(wk, 0, GETDATE()), 0);
31 
32 --查询昨天日期:
33 SELECT CONVERT(CHAR, DATEADD(DD, -1, GETDATE()), 111);  --111是样式号,(100-114)
34 
35 
36 --查询本月第一天日期:
37 SELECT DATEADD(mm, DATEDIFF(mm, 0, GETDATE()), 0) AS firstday;
38 
39 --查询本月最后一天日期:
40 SELECT DATEADD(ms, -3, DATEADD(mm, DATEDIFF(m, 0, GETDATE()) + 1, 0)) as lastday;      --修改-3的值会有相应的变化
41 
42 --本月有多少天:
43 SELECT DATEPART(dd, DATEADD(dd, -1, DATEADD(mm,1, CAST((CAST(YEAR(GETDATE()) AS VARCHAr) + '-' + CAST(MONTH(GETDATE()) AS VARCHAR)+'-01' ) AS DATETIME ))));
44 
45 --求两个时间段相差几天:
46 SELECT DATEDIFF(day, '2012/8/1',' 2012/8/20') as daysum;
47 --在指定的日期上±N天:
48 SELECT CONVERT(CHAR,DATEADD(dd,1,'2012/8/20'),111) as riqi;    --输出2012/8/21
49 
50 --在指定的日期上±N分钟:
51 SELECT DATEADD(mi, -15, GETDATE());  --查询当前时间15分钟之前的日期
原文地址:https://www.cnblogs.com/liuxiaoji/p/4762335.html