zoukankan      html  css  js  c++  java
  • SQL Server 获取本周,本月,本年等时间内记录

    datediff(week,zy_time,getdate())=0 //查询本周

    datediff(month,zy_time,getdate())=0 //查询本月

    本季:select * from table where datediff(qq,C_CALLTIME,getdate())=0
    前半年1-6,后半年7-12:select * from table where datepart(mm,C_CALLTIME)/7 = datepart(mm,getdate())/7

    1. 当前系统日期、时间
    select getdate()

    2. dateadd 在向指定日期加上一段时间的基础上,返回新的 datetime 值
    例如:向日期加上2天
    select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.000

    3. datediff 返回跨两个指定日期的日期和时间边界数。
    select datediff(day,'2004-09-01','2004-09-18') --返回:17

    4. datepart 返回代表指定日期的指定日期部分的整数。
    SELECT DATEPART(month, '2004-10-15') --返回 10

    5. datename 返回代表指定日期的指定日期部分的字符串
    SELECT datename(weekday, '2004-10-15') --返回:星期五

    6. day(), month(),year() --可以与datepart对照一下

    select 当前日期=convert(varchar(10),getdate(),120)
    ,当前时间=convert(varchar(8),getdate(),114)

    select datename(dw,'2004-10-15')

    select 本年第多少周=datename(week,'2004-10-15')
    ,今天是周几=datename(weekday,'2004-10-15')

    函数 参数/功能
    GetDate( ) 返回系统目前的日期与时间
    DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 与date1两个日期之间的差值 date2-date1
    DateAdd (interval,number,date) 以interval指定的方式,加上number之后的日期
    DatePart (interval,date) 返回日期date中,interval指定部分所对应的整数值
    DateName (interval,date) 返回日期date中,interval指定部分所对应的字符串名称

    参数 interval的设定值如下:

    缩 写(Sql Server) Access 和 ASP 说明
    Year Yy yyyy 年 1753 ~ 9999
    Quarter Qq q 季 1 ~ 4
    Month Mm m 月1 ~ 12
    Day of year Dy y 一年的日数,一年中的第几日 1-366
    Day Dd d 日,1-31
    Weekday Dw w 一周的日数,一周中的第几日 1-7
    Week Wk ww 周,一年中的第几周 0 ~ 51
    Hour Hh h 时0 ~ 23
    Minute Mi n 分钟0 ~ 59
    Second Ss s 秒 0 ~ 59
    Millisecond Ms - 毫秒 0 ~ 999

    access 和 asp 中用date()和now()取得系统日期时间;其中DateDiff,DateAdd,DatePart也同是能用于Access和asp中,这些函数的用法也类似

    举例:
    1.GetDate() 用于sql server :select GetDate()

    2.DateDiff('s','2005-07-20','2005-7-25 22:56:32')返回值为 514592 秒
    DateDiff('d','2005-07-20','2005-7-25 22:56:32')返回值为 5 天

    3.DatePart('w','2005-7-25 22:56:32')返回值为 2 即星期一(周日为1,周六为7)
    DatePart('d','2005-7-25 22:56:32')返回值为 25即25号
    DatePart('y','2005-7-25 22:56:32')返回值为 206即这一年中第206天
    DatePart('yyyy','2005-7-25 22:56:32')返回值为 2005即2005年

    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 * from feedback WHERE (DATEDIFF(d,fedtime,GETDATE())=0) ORDER BY fedid DESC
    

      

    本文来源:https://www.cnblogs.com/jkqnb/p/5812395.html

  • 相关阅读:
    49. 字母异位词分组
    73. 矩阵置零
    Razor语法问题(foreach里面嵌套if)
    多线程问题
    Get json formatted string from web by sending HttpWebRequest and then deserialize it to get needed data
    How to execute tons of tasks parallelly with TPL method?
    How to sort the dictionary by the value field
    How to customize the console applicaton
    What is the difference for delete/truncate/drop
    How to call C/C++ sytle function from C# solution?
  • 原文地址:https://www.cnblogs.com/crrc/p/11539868.html
Copyright © 2011-2022 走看看