您的位置:首页 > 数据库

SQL获取每月最后一天记录

2013-12-04 13:06 274 查看

SQL获取每月最后一天记录

DECLARE@dtdatetime

SET@dt=GETDATE()

DECLARE@numberint

SET@number=3

--1.指定日期该年的第一天或最后一天

--A. 年的第一天

SELECTCONVERT(char(5),@dt,120)+'1-1'

--B. 年的最后一天

SELECTCONVERT(char(5),@dt,120)+'12-31'

--2.指定日期所在季度的第一天或最后一天

--A. 季度的第一天

SELECTCONVERT(datetime,

CONVERT(char(8),

DATEADD(Month,

DATEPART(Quarter,@dt)*3-Month(@dt)-2,

@dt),

120)+'1')

--B. 季度的最后一天(CASE判断法)

SELECTCONVERT(datetime,

CONVERT(char(8),

DATEADD(Month,

DATEPART(Quarter,@dt)*3-Month(@dt),

@dt),

120)

+CASEWHENDATEPART(Quarter,@dt)in(1,4)

THEN'31'ELSE'30'END)

--C. 季度的最后一天(直接推算法)

SELECTDATEADD(Day,-1,

CONVERT(char(8),

DATEADD(Month,

1+DATEPART(Quarter,@dt)*3-Month(@dt),

@dt),

120)+'1')

--3.指定日期所在月份的第一天或最后一天

--A. 月的第一天

SELECTCONVERT(datetime,CONVERT(char(8),@dt,120)+'1')

--B. 月的最后一天

SELECTDATEADD(Day,-1,CONVERT(char(8),DATEADD(Month,1,@dt),120)+'1')

--C. 月的最后一天(容易使用的错误方法)

SELECTDATEADD(Month,1,DATEADD(Day,-DAY(@dt),@dt))

--4.指定日期所在周的任意一天

SELECTDATEADD(Day,@number-DATEPART(Weekday,@dt),@dt)

--5.指定日期所在周的任意星期几

--A. 星期天做为一周的第1天

SELECTDATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-1)%7,@dt)

--B. 星期一做为一周的第1天

SELECTDATEADD(Day,@number-(DATEPART(Weekday,@dt)+@@DATEFIRST-2)%7-1,@dt)

查询当前周:

select * from table

where datediff(wk,startdate,getdate())=0

查询下一周(也就是当前周的下一周):

select * from table

where datediff(wk,startdate,getdate())=-1

查询上一周(也就是当前周的上一周):

select * from table

where datediff(wk,startdate,getdate())=1

select DATEADD(wk,DATEDIFF(wk,0,getdate()),0),DATEADD(wk,DATEDIFF(wk,0,getdate()),6)

C#获取上周周日,周六
DateTime dtNow = DateTime.Now;//系统当前时间

DateTime dtLastSun;//上周周日

DateTime dtLastSat;//上周周六

dtLastSun = dtNow.AddDays(-(int)dtNow.DayOfWeek - 7);

dtLastSat = dtNow.AddDays(-(int)dtNow.DayOfWeek - 1);
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: