SQL查询本周本月的问题

 

 

sql 查询本周本月问题

 

---求相差天数  

select   datediff(day,'2004-01-01',getdate())      

    

--1.一个月第一天的  

SELECT   DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0)  

    

--2.本周的星期一  

SELECT   DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0)  

    

select   dateadd(wk,datediff(wk,0,getdate()),6)  

 

--3.一年的第一天  

SELECT   DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0)  

    

--4.季度的第一天  

SELECT   DATEADD(qq,  DATEDIFF(qq,0,getdate()),  0)  

    

--5.当天的半夜  

SELECT   DATEADD(dd,  DATEDIFF(dd,0,getdate()),   0)  

    

--6.上个月的最后一天  

SELECT   dateadd(ms,-3,DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0))  

    

--7.去年的最后一天  

SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0))  

    

--8.本月的最后一天  

SELECT   dateadd(ms,-3,DATEADD(mm,   DATEDIFF(m,0,getdate())+1,   0))  

    

--9.本年的最后一天  

SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate())+1,   0))  

    

--10.本月的第一个星期一  

select   DATEADD(wk,  

DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())),   0)

 

--查询本周注册人数   

select   count(*)  from   [user]  

where   datediff(week,create_day-1,getdate())=0  

    

--上周注册人数  

select   count(*)  from   [user]  

where   datediff(week,create_day-1,getdate())=1  

    

    

--本月注册人数  

select   count(*)  from   [user]  

where   datediff(month,create_day,getdate())=0  

    

--上月注册人数  

select   count(*)  from   [user]  

where   datediff(month,create_day,getdate())=1  

  

--如果要效率,这样写查询  

    

--查询本周注册人数  

select   count(*)  from   [user]  

where   create_day>=dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))  

and  create_day<dateadd(day,9-datepart(weekday,getdate()),convert(varchar,getdate(),112))  

    

--上周注册人数  

select   count(*)  from   [user]  

where   create_day>=dateadd(day,-5-datepart(weekday,getdate()),convert(varchar,getdate(),112))  

and  create_day<dateadd(day,2-datepart(weekday,getdate()),convert(varchar,getdate(),112))  

    

    

--本月注册人数  

select   count(*)  from   [user]  

where   create_day>=dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))  

and  create_day<dateadd(month,1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))  

    

--上月注册人数  

select   count(*)  from   [user]  

where  create_day>=dateadd(month,-1,dateadd(day,1-day(getdate()),convert(varchar,getdate(),112)))  

and  create_day<dateadd(day,1-day(getdate()),convert(varchar,getdate(),112))  

  

--本周  

select   count(*)  from   User  

where   datediff(dd,create_day,getdate())   <=  datepart(dw,getdate())  

         

--上周  

select   count(*)  from   User  

where   datediff(dd,create_day,(getdate()   -  datepart(dw,getdate())))   <=   7  

    

--本月  

select   count(*)  from   User  

where   datepart(mm,create_day)   =  datepart(mm,getdate())  

 

--上月  

select   count(*)  from   User  

where   datepart(mm,create_day)   =  datepart(mm,getdate())   -   1

 

--本周  

select   count(*)  from   [User]  

where   datediff(dd,create_day,getdate())   <=  datepart(dw,getdate())  

        

--上周  

select   count(*)  from   [User]  

where   datediff(dd,create_day,(getdate()   -  datepart(dw,getdate())))   <=   7  

    

--本月  

select   count(*)  from   [User]  

where   datepart(mm,create_day)   =  datepart(mm,getdate())  

--上月  

select   count(*)  from   [User]  

where   datepart(mm,create_day)   =  datepart(mm,getdate())   -   1

学习  

month(create_day)=month(getdate())本月  

month(create_day)=month(getdate())-1   上月

 

补充查询今日所有的

SELECT * fromfeedback WHERE (DATEDIFF(d,fedtime,GETDATE())=0) ORDER BY fedid DESC

 

本篇文章来源于 Linux公社网站(www.linuxidc.com)  原文链接:http://www.linuxidc.com/Linux/2012-03/56268.htm

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值