• SQL语句中日期的计算方法大全


    sql语句中的日期处理
    一.日期處理函數
    1.日期增減函數 
    dateadd(datepart,number,dtae) 
    datepart:是規定應向日期的哪一部分返回新值的參數。下列是sql server支持的日期部分縮寫及含義。 
    日期部分     縮寫                   含義 
    year    yy,yyyy     年份 
    quarter     qq,q    季度 
    month     mm,m    月份 
    dayofyear     dy,y    日 
    day                      dd,d                    
    week    wk,ww    星期 
    hour      hh    小時 
    minute      mi,n    分鐘 
    second      ss,s    秒 
    millisecond     ms    毫秒 
     
    number:是用來增加datepart的值。正數表示增加,負數表示減少,如果指定的是非整數值,則忽略此值的小 
    數部分,不做四舍五入處理,例如,dateadd(day,1.7,date),表示date增加1天。 
    date:是返回datetime或smalldatetime值或日期格式字符串的表達式。 
    2.日期差值計算函數 
    datediff(datepart,startdate,enddate) 
    datepart:規定了應在日期的哪一部分計算差值。 
    startdate:計算的開始日期。 
    enddate:計算的終止日期。 
     
    set datefirst函數是設置一周的第一天是星期幾。 
     
    二.日期推算處理 
    1.指定日期該年的第一天或最後一天 
    對於年的第一天或最後一天,它們的月日信息(第一天為1月1日、最後一天為12月31日)都是固定的,反以只需取 
    出指定日期的年份,再加上月份和天(字符串相加)就可以了。 
    年的第一天: 
    select convert(char(5),<date>,+"1-1" 
    年的最後一天: 
    select convert(char(5),<date>,+12-31" 
     
    2.指定日期所在季度的第一天或最後一天 
    首先分析月份,可以用Datepart(quarter,date)函數取得指定日期所在的季度,一個季度有3個月份,所以datepart(quarter,date)*3就是該季度的最後一個月的月份,再減去2就是該季度最早一個月的月份。接下來要把指定日期的月份轉換到這個推算出的月份,可以把指定日期減去指定日期的月份數,得到指定日期所在年的上一年的最後一個月,然後再加上由季度推算出來的月份數。 
    再分析天的處理,對於第一天,可以直接取得換算後的年月信息字符串,再用字符串相加上天的信息,轉換回日期型就是指定日期所在季度的第一天;對於最後一天,由於一年就4個季度,對就的每季度的最後一個月份分別是3、6、9、12這4個月,它們的最後一天是確定的,分別是31、30、30、31,所以完全可以用CASE來判斷處理。另一種方法用所在季度最後一個月的下一個月的第一天減1天。 
    季度的第一天: 
    select conver(datetime,convert(char(8),dateadd(month,datepart(quarter,<date>)*3-2,dateadd(month,-month(<date>),<date>)),120)+"1") 
    季度的最後一天(CASE判斷法):select convert(datetime,convert(char(8),dateadd(month,datepart(quarter,)*3,dateadd(month,-month(<date>),<date>)),120)+case when datepart(quarter,<date>) in(1,4) then '31' else'30' end) 
    季度的最後一天直接推算法: 
    dateadd(day,-1,convert(char(8),dateadd(month,datepart(quarter,<date>)*3+1,dateadd(month,-month(<date>),<date>)),120)+'1') 
     
    3.指定日期所在月份的第一天或最後一天 
    所在月份的第一天固定為1,只需要取出指定日期的年月部份再加上1就行了。對於月份的最後一天,它隨月份不同而不同,而且還會受平年與閏年的影響,不過當前月份的最後一天肯定是它下個月的1號減去1天,而下個月的1號很容易確定,所以只需要取得指定日期的下個月的1號的日期,然後減1天就行了。 
    在推算日期所在月份最後一天的處理中,一個容易犯的錯誤是:將指定日期減去當前日期的天數,得到指定日期的上一個月的最後一天。如使用這種處理方法,當指定日期上個月的天數比指定日期把在月份的天數多時,不會出現問題。否則就會少計算天數。 
    月的第一天: 
    select convert(datetime,convert(char(8),<date>,120)+'1') 
    月的最後一天: 
    select dateadd(day,-1,convert(char(8),dateadd(month,1,<date>),<date>),120)+'1') 
    月的最後一天(容易使用的錯誤方法): 
    select dateadd(month,1,dateadd(day,-day(<date>,<date>)) 
     
    4.計算年齡 
    要計算准確的年齡,可以這樣考慮,將出生日期的月日部分與當前的日期的月日部分做比較,如果是大於的情況,則表明今年的生日還沒有到,應該將當前日期減去出生日期的結果再減1年,否則直接是現兩個日期年份相減。但這做忽略了一個特殊的日期:閏年的2月29號,這個日期出的人,在平年的時候,應該是2月28號生日,按上面的處理方法恰好是錯過了一天,所以完善的解決方法是,將出生日期的年份增加到與當前日期相同,然後再與當前日期比較,如果大於,則年齡為當前日期減去出生日期的結果再減1年,否則是兩個日期直接相減。 
    處理代碼如下(其中,<birthday>是出生日期,<current_date>是當前日期)。 
    select datediff(year,<birthday>,<current_date>)-case when dateadd(year,datediff(year,<birthday>,<current_date>,<birthday>)><current_date> then 1 else 0 end 
     
    日期处理方法 
    1)去掉时分秒 
    declare @ datetime 
    set @ = getdate() --'2003-7-1 10:00:00' 
    SELECT @,DATEADD(day, DATEDIFF(day,0,@), 0) 
    2)显示星期几 
    select datename(weekday,getdate()) 
    3)如何取得某个月的天数 
    declare @m int 
    set @m=2 --月份 
    select datediff(day,'2003-'+cast(@m as varchar)+'-15' ,'2003-'+cast(@m+1 as varchar)+'-15') 
    另外,取得本月天数 
    select datediff(day,cast(month(GetDate()) as varchar)+'-'+cast(month(GetDate()) as varchar)+'-15' ,cast(month(GetDate()) as varchar)+'-'+cast(month(GetDate())+1 as varchar)+'-15') 
    或者使用计算本月的最后一天的脚本,然后用DAY函数区最后一天 
    SELECT Day(dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))) 
    4)判断是否闰年: 
    SELECT case day(dateadd(mm, 2, dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)))) when 28 then '平年' else '闰年' end 
    或者 
    select case datediff(day,datename(year,getdate())+'-02-01',dateadd(mm,1,datename(year,getdate())+'-02-01')) 
    when 28 then '平年' else '闰年' end 
    5)一个季度多少天 
    declare @m tinyint,@time smalldatetime 
    select @m=month(getdate()) 
    select @m=case when @m between 1 and 3 then 1 
    when @m between 4 and 6 then 4 
    when @m between 7 and 9 then 7 
    else 10 end 
    select @time=datename(year,getdate())+'-'+convert(varchar(10),@m)+'-01' 
    select datediff(day,@time,dateadd(mm,3,@time)) 

    SQL语句中日期的计算

    1. 本月的第一天
    SELECT  DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0) 

    2. 本月的最后一天
    SELECT  dateadd(ms,-3,DATEADD(mm,  DATEDIFF(m,0,getdate())+1,  0)) 

    3.上个月的第一天
    select dateadd(m,-1,  DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0))

    4. 上个月的最后一天 
    SELECT  dateadd(ms,-3,DATEADD(mm,  DATEDIFF(mm,0,getdate()),  0)) 

    5. 本周的星期一
    SELECT  DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0)

    6.本周的周日
    select dateadd(d,+6 ,DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0) )

    7.上周的星期一
    select dateadd(d,-7 ,DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0) )

    8.上周的周日
    select dateadd(d,-1 ,DATEADD(wk,  DATEDIFF(wk,0,getdate()),  0) )

    9. 一年的第一天
    SELECT  DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0) 

    10. 季度的第一天
    SELECT  DATEADD(qq,  DATEDIFF(qq,0,getdate()),  0) 

    11. 去年的最后一天
    SELECT  dateadd(ms,-3,DATEADD(yy,  DATEDIFF(yy,0,getdate()),  0))

    12. 本月的第一个星期一
    select  DATEADD(wk,  DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate)),getdate))),0)

    13. 本年的最后一天
    SELECT  dateadd(ms,-3,DATEADD(yy,  DATEDIFF(yy,0,getdate())+1,  0))。


    Sql Server中的日期与时间函数 
    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')


    http://www.52186.cn/nibablog/blogview.asp?logID=333

    sql日期格式转换

    --------------------------------------------------------------------------------

     
     
    在sql中,smalldatetime及datetime型的数据显示不是那么让人满意,因此我找了些格式化的方法列出来"

    convert(char(10),datetime,101)


    在数据库取出来的时候就转换好
     select getdate()
     
     2006-05-12 11:06:08.177
     
     我整理了一下SQL Server里面可能经常会用到的日期格式转换方法:
     
     举例如下:
     select Convert(varchar(10),getdate(),120)

    2006-05-12 
     select CONVERT(varchar, getdate(), 120 )
     2006-05-12  11:06:08

     select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','')
     20060512110608
     
     select CONVERT(varchar(12) , getdate(), 111 )
     2006/05/12
     
     select CONVERT(varchar(12) , getdate(), 112 )
     20060512

     select CONVERT(varchar(12) , getdate(), 102 )
     2006.05.12
     
     其它几种不常用的日期格式转换方法:

     select CONVERT(varchar(12) , getdate(), 101 )
     0612/2005 select CONVERT(varchar(12) , getdate(), 103 )
     12/09/2004

     select CONVERT(varchar(12) , getdate(), 104 )
     12.05.2006

     select CONVERT(varchar(12) , getdate(), 105 )
     12-05-2006

     select CONVERT(varchar(12) , getdate(), 106 )
     12 05 2006

     select CONVERT(varchar(12) , getdate(), 107 )
     05 12, 2006

     select CONVERT(varchar(12) , getdate(), 108 )
     11:06:08
     
     select CONVERT(varchar(12) , getdate(), 109 )
     0512 2006 1

     select CONVERT(varchar(12) , getdate(), 110 )
     09-12-2004

     select CONVERT(varchar(12) , getdate(), 113 )
     12 052006

     select CONVERT(varchar(12) , getdate(), 114 )
     11:06:08.177
     

    ============================================================================================
    实例演练

    select * from salesmb
    select count(*) from salesdreport where employeeid='11'and productsid='7' and (updatetime between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --销售数量
    select sum(sales) from salesmb where eid='11'and productsid='7' and (mbrq between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --目标数量

    select dateadd(d,-day(getdate()),getdate())

    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-'+cast(day(getdate()) as varchar)

    select dateadd(m,1,dateadd(d,-day(getdate()),getdate()))


    select dateadd(m,1,getdate())


    =====================================================================================================================================================


    select * from salesmb
    select count(*) from salesdreport where employeeid='11'and productsid='7' and (updatetime between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --销售数量
    select sum(sales) from salesmb where eid='11'and productsid='7' and (mbrq between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --目标数量

    select dateadd(d,-day(getdate()),getdate())

    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-'+cast(day(getdate()) as varchar)

    select dateadd(m,1,dateadd(d,-day(getdate()),getdate()))


    select dateadd(m,1,getdate())


    ======================================================================================================================================================

    select * from salesmb
    select count(*) from salesdreport where employeeid='11'and productsid='7' and (updatetime between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --销售数量
    select sum(sales) from salesmb where eid='11'and productsid='7' and (mbrq between '2006-8-1 00:00:00'and '2006-8-30 00:00:00') --目标数量

    select dateadd(d,-day(getdate()),getdate())

    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-'+cast(day(getdate()) as varchar)

    select dateadd(m,1,dateadd(d,-day(getdate()),getdate()))


    select dateadd(m,1,getdate())

    ===============================================================================================================================


    select getdate()
    select dateadd(d,1,dateadd(d,-day(getdate()),getdate()))+"00:00"

    declare @sdate smalldatetime
    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'
    select @sdate
    select dateadd(day,-1,dateadd(Month,1,@sdate))

    select cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'

    select dateadd(d,-day(getdate()),getdate())

    select dateadd(day,-1,dateadd(Month,1,cast(year(getdate()) as nvarchar)+'-'+cast(month(getdate()) as varchar)+'-1 00:00'))

    select dateadd(d,-day(getdate()),getdate())

    select dateadd(d,1,dateadd(d,-day(getdate()),getdate()))
    select dateadd(m,

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

  • 相关阅读:
    《一带一路与黄河文明》:4星。用经济学角度与思维重新看明史。
    《谁动了我的网络资产》:4星。移动互联时代的软件使用技巧。
    《畅销的原理》:4星。关于判断与决策的研究的综述。
    《清明上河图密码4》:5星。严重剧透。依旧是细节+推理的双绝。隐隐看到有敌国的间谍盗窃经济地图、劫持手工业顶尖人才。
    《哈佛商业评论》2017年第5期:4星。成功CEO具有4种行为特质:果断、激励参与、主动适应、稳扎稳打。股东价值最大化的理念有重大缺陷。
    《屏幕上的聪明决策》:4星。人类在手机/电脑上做选择的心理学研究的综述。不流畅的文本有助于理解和记忆,淘汰赛制可以有效降低选择后懊悔。
    《三联生活周刊》2017年17期:3星。电子版阅读体验远超纸版。如果雄安的土地制度实验成功了,“北上广深”的房价也就被釜底抽薪了。
    《岁月凶猛》:3星。作者对人生与商业的感悟,商业圈内一些真实的故事。
    《神秘的镜像神经元》:2星。比较专业,许多内容看不懂。应该去学术期刊上发表观点而不是写成科普书向外行宣传。
    《拯救你的注意力》:4星。很多重要的领导力技能,包括情商、组织和战略思考能力都起源于对注意力的把控。
  • 原文地址:https://www.cnblogs.com/xqfk/p/12887087.html
Copyright © 2020-2023  润新知