国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

在SQL語句中實現(xiàn)日期格式的加減運算

2024-05-04 11:06:07
字體:
供稿:網(wǎng)友

今天在工作中遇到了一個問題,需要按時間查詢,可是查詢出來的結(jié)果顯示的不正確。舉個例子來說,要查找出2007-10-12至2007-10-31之間在網(wǎng)站上注冊的會員,選擇好日期后,點擊“查詢”按鈕,發(fā)現(xiàn)2007-10-31注冊的會員的信息根本沒有顯示出來,試驗了幾次結(jié)果都是一樣。調(diào)試程序發(fā)現(xiàn),原來是在SQL語句這里出現(xiàn)了問題。

SQL語句如下:SELECT * FROM userinfo WHERE regtime >= '2007-10-12' AND regtime <= '2007-10-31'。初看上去這條SQL語句沒有錯誤,可是對照數(shù)據(jù)庫中相應字段保存的值以后,發(fā)現(xiàn)保存的值并不是簡單的日期形式,而是日期+時間的形式,即:yyyy-MM-dd HH:mm:ss,這時SQL語句在判斷regtime和'2007-10-31'的大小時,會認為'2007-10-31'寫的不完整,所以不會認為這兩個值是相等的。這可怎么辦呢?

不用著急,ASP為我們提供了日期加減的函數(shù),來幫我們解決這一問題。

1、日期相加

DateAdd 函數(shù)

 

返回已添加指定時間間隔的日期。

DateAdd(interval, number, date)

DateAdd 函數(shù)的語法有以下參數(shù)

(1)interval 必選項。字符串表達式,表示要添加的時間間隔。有關(guān)數(shù)值,請參閱“設置”部分。

(2)number 必選項。數(shù)值表達式,表示要添加的時間間隔的個數(shù)。數(shù)值表達式可以是正數(shù)(得到未來的日期)或負數(shù)(得到過去的日期)。

(3)date 必選項。Variant 或要添加 interval 的表示日期的文字。

說明:

可用 DateAdd 函數(shù)從日期中添加或減去指定時間間隔。例如可以使用 DateAdd 從當天算起 30 天以后的日期或從現(xiàn)在算起 45 分鐘以后的時間。要向 date 添加以“日”為單位的時間間隔,可以使用“一年的日數(shù)”(“y”)、“日”(“d”)或“一周的日數(shù)”(“w”)。

DateAdd 函數(shù)不會返回無效日期。如下示例將 95 年 1 月 31 日加上一個月:

NewDate = DateAdd("m", 1, "31-Jan-95")

在這個示例中,DateAdd 返回 95 年 2 月 28 日,而不是 95 年 2 月 31 日。如果 date 為 96 年 1 月 31 日,則返回 96 年 2 月 29 日,這是因為 1996 是閏年。

如果計算的日期是在公元 100 年之前,則會產(chǎn)生錯誤。

如果 number 不是 Long 型值,則在計算前四舍五入為最接近的整數(shù)。

2、日期相減

DateDiff 函數(shù)

返回兩個日期之間的時間間隔。

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

DateDiff 函數(shù)的語法有以下參數(shù):

(1)interval 必選項。字符串表達式,表示用于計算 date1 和 date2 之間的時間間隔。有關(guān)數(shù)值,請參閱“設置”部分。

(2)date1, date2 必選項。日期表達式。用于計算的兩個日期。

(3)Firstdayofweek 可選項。指定星期中第一天的常數(shù)。如果沒有指定,則默認為星期日。有關(guān)數(shù)值,請參閱“設置”部分。

(4)Firstweekofyear 可選項。指定一年中第一周的常數(shù)。如果沒有指定,則默認為 1 月 1 日所在的星期。有關(guān)數(shù)值,請參閱“設置”部分。

說明:

DateDiff 函數(shù)用于判斷在兩個日期之間存在的指定時間間隔的數(shù)目。例如可以使用 DateDiff 計算兩個日期相差的天數(shù),或者當天到當年最后一天之間的星期數(shù)。

要計算 date1 和 date2 相差的天數(shù),可以使用“一年的日數(shù)”(“y”)或“日”(“d”)。當 interval 為“一周的日數(shù)”(“w”)時,DateDiff 返回兩個日期之間的星期數(shù)。如果 date1 是星期一,則 DateDiff 計算到 date2 之前星期一的數(shù)目。此結(jié)果包含 date2 而不包含 date1。如果 interval 是“周”(“ww”),則 DateDiff 函數(shù)返回日歷表中兩個日期之間的星期數(shù)。函數(shù)計算 date1 和 date2 之間星期日的數(shù)目。如果 date2 是星期日,DateDiff 將計算 date2,但即使 date1 是星期日,也不會計算 date1。

如果 date1 晚于 date2,則 DateDiff 函數(shù)返回負數(shù)。

firstdayofweek 參數(shù)會對使用“w”和“ww”間隔符號的計算產(chǎn)生影響。

如果 date1 或 date2 是日期文字,則指定的年度會成為日期的固定部分。但是如果 date1 或 date2 被包括在引號 (" ") 中并且省略年份,則在代碼中每次計算 date1 或 date2 表達式時,將插入當前年份。這樣就可以編寫適用于不同年份的程序代碼。

在 interval 為“年”(“yyyy”)時,比較 12 月 31 日和來年的 1 月 1 日,雖然實際上只相差一天,DateDiff 返回 1 表示相差一個年份。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 许昌市| 临泉县| 德惠市| 毕节市| 池州市| 临汾市| 信宜市| 荆州市| 遵义市| 北宁市| 科尔| 宁德市| 德清县| 五台县| 浦城县| 哈密市| 英超| 邯郸市| 政和县| 深泽县| 和政县| 卓资县| 贡山| 新丰县| 广安市| 万山特区| 聊城市| 隆林| 阿瓦提县| 双桥区| 阿坝| 曲阳县| 清涧县| 伊金霍洛旗| 青海省| 延庆县| 湟源县| 句容市| 江阴市| 保德县| 望城县|