资源描述:
《sql server中一些有用的日期sql语句会员杂谈 - 博罗论坛》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、SQLServer中一些有用的日期sql语句会员杂谈-博罗论坛SQLServer中一些有用的日期sql语句legend2008于2004年07月23日发表SQLServer中一些有用的日期sql语句作者:不祥 时间:2004-3-21.一个月第一天的SELECTDATEADD(mm,DATEDIFF(mm,0,getdate()),0)2.本周的星期一SELECTDATEADD(wk,DATEDIFF(wk,0,getdate()),0)3.一年的第一天SELECTDATEADD(yy,DATEDIFF(yy,0,getdate()),0)4.季
2、度的第一天SELECTDATEADD(qq,DATEDIFF(qq,0,getdate()),0)5.当天的半夜SELECTDATEADD(dd,DATEDIFF(dd,0,getdate()),0)6.上个月的最后一天SELECTdateadd(ms,-3,DATEADD(mm,DATEDIFF(mm,0,getdate()),0))7.去年的最后一天SELECTdateadd(ms,-3,DATEADD(yy,DATEDIFF(yy,0,getdate()),0))8.本月的最后一天SELECTdateadd(ms,-3,DATEADD(mm
3、,DATEDIFF(m,0,getdate())+1,0))9.本年的最后一天SELECTdateadd(ms,-3,DATEADD(yy,DATEDIFF(yy,0,getdate())+1,0))10.本月的第一个星期一selectDATEADD(wk,DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())),0)11.今天的日期select{fnCURDATE()}astoday------------------------------------------------
4、--------------------------------SQLServer日期计算关键字:数据库,SQLSERVER,DATEDIFF,DATEADD通常,你需要获得当前日期和计算一些其他的日期,例如,你的程序可能需要判断一个月的第一天或者最后一天。你们大部分人大概都知道怎样把日期进行分割(年、月、日等),然后仅仅用分割出来的年、月、日等放在几个函数中计算出自己所需要的日期!在这篇文章里,我将告诉你如何使用DATEADD和DATEDIFF函数来计算出在你的程序中可能你要用到的一些不同日期。在使用本文中的例子之前,你必须注意以下的问题。大部
5、分可能不是所有例子在不同的机器上执行的结果可能不一样,这完全由哪一天是一个星期的第一天这个设置决定。第一天(DATEFIRST)设定决定了你的系统使用哪一天作为一周的第一天。所有以下的例子都是以星期天作为一周的第一天来建立,也就是第一天设置为7。假如你的第一天设置不一样,你可能需要调整这些例子,使它和不同的第一天设置相符合。你可以通过@@DATEFIRST函数来检查第一天设置。为了理解这些例子,我们先复习一下DATEDIFF和DATEADD函数。DATEDIFF函数计算两个日期之间的小时、天、周、月、年等时间间隔总数。DATEADD函数计算一个日
6、期通过给时间间隔加减来获得一个新的日期。要了解更多的DATEDIFF和DATEADD函数以及时间间隔可以阅读微软联机帮助。使用DATEDIFF和DATEADD函数来计算日期,和本来从当前日期转换到你需要的日期的考虑方法有点不同。你必须从时间间隔这个方面来考虑。比如,从当前日期到你要得到的日期之间有多少时间间隔,或者,从今天到某一天(比如1900-1-1)之间有多少时间间隔,等等。理解怎样着眼于时间间隔有助于你轻松的理解我的不同的日期计算例子。一个月的第一天第一个例子,我将告诉你如何从当前日期去这个月的最后一天。请注意:这个例子以及这篇文章中的其他
7、例子都将只使用DATEDIFF和DATEADD函数来计算我们想要的日期。每一个例子都将通过计算但前的时间间隔,然后进行加减来得到想要计算的日期。这是计算一个月第一天的SQL脚本:SELECTDATEADD(mm,DATEDIFF(mm,0,getdate()),0)我们把这个语句分开来看看它是如何工作的。最核心的函数是getdate(),大部分人都知道这个是返回当前的日期和时间的函数。下一个执行的函数DATEDIFF(mm,0,getdate())是计算当前日期和“1900-01-0100:00:00.000”这个日期之间的月数。记住:时期和时间
8、变量和毫秒一样是从“1900-01-0100:00:00.000”开始计算的。这就是为什么你可以在DATEDIFF函数中指定第一个时间表