SQL中时间函数总结(一)


①DATEADD\DAY\DATEDIFF\GETDATE\DATENAME等函数的用法. 
②想查询2007年2月9日的付款流水有单笔交易出现多张小票号的情况的小票号,该用什么语句? 
提问者: 420329630 - 助理 二级 
最佳答案 
1.DateAdd ( I , N , D ) 
将一个日期加上一段期间后的日期。 I :设定一个日期( Date )所加上的一段期间的单位。譬如 interval="d" 表示 N的单位为日。 I的设定值如下: 
yyyy Year 年 
q Quarter 季 
m Month 月 
d Day 日 
w Weekday 星期 
h Hour 时 
n Minute 分 
s Second 秒 
N :数值表达式,设定一个日期所加上的一段期间,可为正值或负值,正值表示加(结果为 >date 以后的日期),负值表示减(结果为 >date 以前的日期)。 
D :待加减的日期。 
例子: DateAdd ( "m" , 1 , "31-Jan-98") 
结果: 28-Feb-98 
说明:将日期 31-Jan-98 加上一个月,结果为 28-Feb-98 而非 31-Fe-98 。 
例子: DateAdd ( "d" , 20 , "30-Jan-99") 
结果: 1999/2/9 
说明:将一个日期 30-Jan-99 加上 20 天后的日期。 

2.Day( 日期的字符串或表达式 ) 
传回日期的「日」部份。 
例子: Day(" 12/1/1999 ") 
结果: 1 

3.DateDiff (I , D1 , D2[,FW[,FY]]) 
计算两个日期之间的期间。 
I :设定两个日期之间的期间计算之单位。譬如 >I="m" 表示计算的单位为月。 >I 的设定值如: 
yyyy > Year 年 
q Quarter 季 
m Month 月 
d Day 日 
w Weekday 星期 
h Hour 时 
n Minute 分 
s Second 秒 
D1 ,D2:计算期间的两个日期表达式,若 >date1 较早,则两个日期之间的期间结果为正值;若 >date2 较早, 则结果为负值。 
FW :设定每周第一天为星期几, 若未设定表示为星期天。 >FW 的设定值如下: 
0 使用 >API 的设定值。 
1 星期天 
2 星期一 
3 星期二 
4 星期三 
5 星期四 
6 星期五 
7 星期六 
FY :设定一年的第一周, 若未设定则表示一月一日那一周为一年的第一周。 >FY 的设定值如下: 
0 使用 >API 的设定值。 
1 一月一日那一周为一年的第一周 
2 至少包括四天的第一周为一年的第一周 
3 包括七天的第一周为一年的第一周 
例子: DateDiff ("d","25-Mar-99 ","30-Jun-99 ") 
结果: 97 
说明:显示两个日期之间的期间为 97 天 


想查询2007年2月9日的付款流水有单笔交易出现多张小票号的情况的小票号 
这个要看一下你的表结构是什么样的啊? 
回答者:qqsmalltiger - 助理 二级 3-3 23:45 
评价已经被关闭    目前有 0 个人评价 
       好 
50% (0) 不好 
50% (0) 

其他回答    共 1 条 
DATEADD 
在向指定日期加上一段时间的基础上,返回新的 datetime 值。 

语法 
DATEADD ( datepart , number, date ) 

DATEDIFF 
返回跨两个指定日期的日期和时间边界数。 

语法 
DATEDIFF ( datepart , startdate , enddate ) 

GETDATE 
按 datetime 值的 Microsoft® SQL Server? 标准内部格式返回当前系统日期和时间。 

语法 
GETDATE ( ) 

DATENAME 
返回代表指定日期的指定日期部分的字符串。 

语法 
DATENAME ( datepart , date ) 



SQL日期计算 
通常,你需要获得当前日期和计算一些其他的日期,例如,你的程序可能需要判断一个月的第一天或者最后一天 

。你们大部分人大概都知道怎样把日期进行分割(年、月、日等),然后仅仅用分割出来的年、月、日等放在几 

个函数中计算出自己所需要的日期!在这篇文章里,我将告诉你如何使用DATEADD和DATEDIFF函数来计算出在你 

的程序中可能你要用到的一些不同日期。 
       在使用本文中的例子之前,你必须注意以下的问题。大部分可能不是所有例子在不同的机器上执行的结 

果可能不一样,这完全由哪一天是一个星期的第一天这个设置决定。第一天(DATEFIRST)设定决定了你的系统 

使用哪一天作为一周的第一天。所有以下的例子都是以星期天作为一周的第一天来建立,也就是第一天设置为7 

。假如你的第一天设置不一样,你可能需要调整这些例子,使它和不同的第一天设置相符合。你可以通过 

@@DATEFIRST函数来检查第一天设置。 

       为了理解这些例子,我们先复习一下DATEDIFF和DATEADD函数。DATEDIFF函数计算两个日期之间的小时、 

天、周、月、年等时间间隔总数。DATEADD函数计算一个日期通过给时间间隔加减来获得一个新的日期。要了解 

更多的DATEDIFF和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函数计算

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/16436858/viewspace-612110/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/16436858/viewspace-612110/

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值