• 售前

  • 售后

热门帖子
入门百科

SQL Server各种日期盘算方法(收藏)

[复制链接]
向往草原403 显示全部楼层 发表于 2021-10-25 20:33:56 |阅读模式 打印 上一主题 下一主题
通常,你必要获恰当前日期和盘算一些其他的日期,比方,你的程序大概必要判断一个月的第一天大概最后一天。你们大部门人大概都知道怎样把日期进行分割(年、月、日等),然后仅仅用分割出来的年、月、日等放在几个函数中盘算出本身所必要的日期!在这篇文 章里,我将告诉你怎样使用DATEADD和DATEDIFF函数来盘算出在你的程序中大概你要用到的一些差别日期。  

  在使用本文中的例子之前,你必须注意以下的标题。大部门大概不是全部例子在差别的机器上实行的结果大概不一样,这完全由哪一天是一个星期的第一天这个设置决定。第一天(DATEFIRST)设定决定了你的体系使用哪一天作为一周的第一天。全部以下的例 子都是以星期天作为一周的第一天来建立,也就是第一天设置为7。假如你的第一天设置不一样,你大概必要调整这些例子,使它和差别的第一天设置相符合。你可以通过@@DATEFIRST函数来检查第一天设置。  
  
  为了明白这些例子,我们先复习一下DATEDIFF和DATEADD函数。DATEDIFF函数盘算两个日期之间的小时、天、周、月、年等时间间隔总数。DATEADD函数盘算一个日期通过给时间间隔加减来获得一个新的日期。要相识更多的DATEDI FF和DATEADD函数以及时间间隔可以阅读微软联机资助。  
  
  使用DATEDIFF和DATEADD函数来盘算日期,和原来从当前日期转换到你必要的日期的考虑方法有点差别。你必须从时间间隔这个方面来考虑。比如,从当前日期到你要得到的日期之间有多少时间间隔,大概,从今天到某一天(比如1900-1-1)之间有多少时间间隔,等等。明白怎样着眼于时间间隔有助于你轻松的明白我的差别的日期盘算例子。  
  
  一个月的第一天
  
  第一个例子,我将告诉你怎样从当前日期去这个月的最后一天。请注意:这个例子以及这篇文章中的其他例子都将只使用DATEDIFF和DATEADD函数来盘算我们想要的日期。每一个例子都将通过盘算但前的时间间隔,然后进行加减来得到想要盘算的日期。  
  
  这是盘算一个月第一天的SQL 脚本:  
  SELECT DATEADD(mm, DATEDIFF(mm,0,getdate()), 0)  
  
  我们把这个语句分开来看看它是怎样工作的。最核心的函数是getdate(),大部门人都知道这个是返回当前的日期和时间的函数。下一个实行的函数DATEDIFF(mm,0,getdate())是盘算当前日期和“1900-01-01 00:00:00.000”这个日期之间的月数。记着:时期和时间变量和毫秒一样是从“1900-01-01 00:00:00.000”开始盘算的。这就是为什么你可以在DATEDIFF函数中指定第一个时间表达式为“0”。下一个函数是DATEADD,增长当前日期到“1900-01-01”的月数。通过增长预界说的日期“1900-01-01”和当前日期的月数,我们可以获得这个月的第一天。别的,盘算出来的日期的时间部门将会是“00:00:00.000”。  
  
  这个盘算的本事是先盘算当前日期到“1900-01-01”的时间间隔数,然后把它加到“1900-01-01”上来获得特别的日期,这个本事可以用来盘算很多差别的日期。下一个例子也是用这个本事从当前日期来产生差别的日期。
本周的星期一  
  
  这里我是用周(wk)的时间间隔来盘算哪一天是本周的星期一。   
  SELECT DATEADD(wk, DATEDIFF(wk,0,getdate()), 0)  
  
  一年的第一天  
  
  如今用年(yy)的时间间隔来表现这一年的第一天。  
  
  SELECT DATEADD(yy, DATEDIFF(yy,0,getdate()), 0)  
  
  季度的第一天  
  
  假如你要盘算这个季度的第一天,这个例子告诉你该怎样做。  
  
  SELECT DATEADD(qq, DATEDIFF(qq,0,getdate()), 0)  
  
  当天的半夜  
  
  曾经必要通过getdate()函数为了返回时间值截掉时间部门,就会考虑到当前日期是不是在半夜。假如如许,这个例子使用DATEDIFF和DATEADD函数来获得半夜的时间点。  
  
  SELECT DATEADD(dd, DATEDIFF(dd,0,getdate()), 0)  
  
  深入DATEDIFF和DATEADD函数盘算  
  
  你可以明白,通过使用简单的DATEDIFF和DATEADD函数盘算,你可以发现很多差别的大概有意义的日期。  
  
  现在为止的全部例子只是仅仅盘算当前的时间和“1900-01-01”之间的时间间隔数量,然后把它加到“1900-01-01”的时间间隔上来盘算出日期。假定你修改时间间隔的数量,大概使用差别的时间间隔来调用DATEADD函数,大概减去时间间隔而不是增长,那么通过这些小的调整你可以发现和多差别的日期。  
  
  这里有四个例子使用别的一个DATEADD函数来盘算最后一天来分别更换DATEADD函数前后两个时间间隔。  
上个月的最后一天  
  
  这是一个盘算上个月最后一天的例子。它通过从一个月的最后一天这个例子上减去3毫秒来获得。有一点要记着,在Sql Server中时间是准确到3毫秒。这就是为什么我必要减去3毫秒来获得我要的日期和时间。  
  
  SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))  
  
  盘算出来的日期的时间部门包罗了一个Sql Server可以记录的一天的最后时候(“23:59:59:997”)的时间。  
  
  客岁的最后一天  
  
  毗连上面的例子,为了要得到客岁的最后一天,你必要在本年的第一天上减去3毫秒。  
  
  SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate()), 0))  
  
  本月的最后一天  
  
  如今,为了获得本月的最后一天,我必要轻微修改一下获得上个月的最后一天的语句。修改必要给用DATEDIFF比力当前日期和“1900-01-01”返回的时间间隔上加1。通过加1个月,我盘算出下个月的第一天,然后减去3毫秒,如许就盘算出了这个月的最后一天。这是盘算本月最后一天的SQL脚本。  
  
  SELECT dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1, 0))  
  
  本年的最后一天   
  你如今应该把握这个的做法,这是盘算本年最后一天脚本  
  
  SELECT dateadd(ms,-3,DATEADD(yy, DATEDIFF(yy,0,getdate())+1, 0))。  
  
  本月的第一个星期一  
  
  好了,如今是最后一个例子。这里我要盘算这个月的第一个星期一。这是盘算的脚本。  
  
  select DATEADD(wk, DATEDIFF(wk,0,  
  dateadd(dd,6-datepart(day,getdate()),getdate())  
  ), 0)  
  
  在这个例子里,我使用了“本周的星期一”的脚本,并作了一点点修改。修改的部门是把原来脚本中“getdate()”部门更换成盘算本月的第6天,在盘算中用本月的第6天来更换当前日期使得盘算可以获得这个月的第一个星期一。  
  
  总结  
  
  我盼望这些例子可以在你用DATEADD和DATEDIFF函数盘算日期时给你一点开导。通过使用这个盘算日期的时间间隔的数学方法,我发现为了表现两个日期之间间隔的有用历法是有代价的。注意,这只是盘算出这些日期的一种方法。要牢记,另有很多方法 可以得到相同的盘算结果。假如你有其他的方法,那很不错,要是你没有,我盼望这些例子可以给你一些开导,当你要用DATEADD和DATEDIFF函数盘算你程序大概要用到的日期时。  
附录,其他日期处理惩罚方法  
  
  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))

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作