MSDN中有关DateDiff函数的错误

添加评论 2008年12月14日

DateDiff可以计算两个日期之间的时间间隔,用起来很方便,在ASP中也经常会用到它来进行一些日期、时间比对的工作。

先来复习一下MSDN中对DateDiff函数的说明,再说问题之所在

DateDiff 函数

描述

返回两个日期之间的时间间隔。

语法

DateDiff(interval, date1, date2 [,firstdayofweek[, firstweekofyear]])

DateDiff 函数的语法有以下参数:

参数 描述
interval 必选项。String expression 表示用于计算 date1date2 之间的时间间隔。有关数值,请参阅“设置”部分。
date1, date2 必选项。日期表达式。用于计算的两个日期。
firstdayofweek 可选项。指定星期中第一天的常数。如果没有指定,则默认为星期日。有关数值,请参阅“设置”部分。
firstweekofyear 可选项。指定一年中第一周的常数。如果没有指定,则默认为 1 月 1 日所在的星期。有关数值,请参阅“设置”部分。
设置

interval 参数可以有以下值:

设置 描述
yyyy
q 季度
n
y 一年的日数
d
w 一周的日数
ww
h 小时
m 分钟
s

firstdayofweek 参数可以有以下值:

常数 描述
vbUseSystem 0 使用区域语言支持 (NLS) API 设置。
vbSunday 1 星期日(默认)
vbMonday 2 星期一
vbTuesday 3 星期二
vbWednesday 4 星期三
vbThursday 5 星期四
vbFriday 6 星期五
vbSaturday 7 星期六

firstweekofyear 参数可以有以下值:

常数 描述
vbUseSystem 0 使用区域语言支持 (NLS) API 设置。
vbFirstJan1 1 由 1 月 1 日所在的星期开始(默认)。
vbFirstFourDays 2 由在新年中至少有四天的第一周开始。
vbFirstFullWeek 3 由在新的一年中第一个完整的周开始。
说明

DateDiff 函数用于判断在两个日期之间存在的指定时间间隔的数目。例
如可以使用 DateDiff 计算两个日期相差的天数,或者当天到当年最后一天之间的星期数。

要计算 date1date2 相差的天数,可以使用“一年的日数”(“y”)或“日”(“d”)。当 interval 为“一周的日数”(“w”)时,DateDiff 返回两个日期之间的星期数。如果 date1 是星期一,则 DateDiff 计算到 date2 之前星期一的数目。此结果包含 date2 而不包含 date1。如果 interval 是“周”(“ww”),则 DateDiff 函数返回日历表中两个日期之间的星期数。函数计算 date1date2 之间星期日的数目。如果 date2 是星期日,DateDiff 将计算 date2,但即使 date1 是星期日,也不会计算 date1

如果 date1 晚于 date2,则 DateDiff 函数返回负数。

firstdayofweek 参数会对使用“w”和“ww”间隔符号的计算产生影响。

如果 date1date2 是日期文字,则指定的年度会成为日期的固定部分。但是如果 date1date2 被包括在引号 (” “) 中并且省略年份,则在代码中每次计算 date1date2 表达式时,将插入当前年份。这样就可以编写适用于不同年份的程序代码。

interval 为“年”(“yyyy”)时,比较 12 月 31 日和来年的 1 月 1 日,虽然实际上只相差一天,DateDiff 返回 1 表示相差一个年份。

下面的示例利用 DateDiff 函数显示今天与给定日期之间间隔天数:

Function DiffADate(theDate)  DiffADate = "从当天开始的天数:" & DateDiff("d", Now, theDate)End Function

照上面的说明,如果我想比较数据库中某日期字段的值与当前时间的间隔是否大于60分钟的话应该是

If DateDiff(“m”, rs(“dt”),Now())>60 Then
……
End If

但在实际使用中发现If内的语句从来不执行,再进一步跟踪后发现DateDiff(“m”, rs(“dt”),Now())的值竟然总等于0,郁闷之下进行了N多测试,才发现原来上面说明中interval 的取值说明有误,实际上”m”是Month, 而分钟应该是”n”。

因为我一开始时用的测试数据全是同一个月的,所以才出现了“恒等于”0的诡异状态出现。换成“n”后一切搞定~~

  1. 还没有评论.想坐沙发?
  1. 还没有 trackbacks
订阅评论