專家回答:
對(duì)于許多跟商業(yè)日期有關(guān)的情況,最好的解決方案是使用日歷表格。例如,使用辦公時(shí)間(2001年5月22日)查詢兩個(gè)日期之間的時(shí)間差。
我們知道在這個(gè)例子中,假日不會(huì)計(jì)算在內(nèi)。很難明白為什么假日不被計(jì)算在內(nèi),但是周末卻會(huì)被計(jì)算在內(nèi)。但是既然假日不被計(jì)算在內(nèi),我們就可以應(yīng)用一個(gè)公式。要開(kāi)發(fā)這個(gè)公式,讓我們首先探討一下所有的可能性。
如果今天是星期一,那么,往回?cái)?shù),我們跳過(guò)星期天和星期六,星期五是一天前,星期四是兩天前,如此類推,那么“五天前”就是上個(gè)星期一。這里的“五天前”就意味著把周末排除出去,得出我們想要的日期,并不是真正字面意義上的五天前。我們可以從備忘錄上看到差別。
如果今天是星期二,那么,往回?cái)?shù),星期一是一天前,跳過(guò)星期天和星期六,星期五是兩天前,星期四是三天前,如此類推,那么“五天前”就是上個(gè)星期二。
這個(gè)模式——“五天前”就是上一個(gè)星期的同一天(星期X)——可重復(fù)到星期三、星期四和星期五。
到了星期六,這個(gè)模式就不可用了。在星期六,五天前是星期一。在星期天,因?yàn)槲覀儾挥?jì)算星期六,五天前也是星期一。
把我們的討論發(fā)現(xiàn)總結(jié)成如下數(shù)據(jù):
要獲得“五天前”的日期,從今天減去的總天數(shù)(包括周末)顯示在右邊列中。
我們給一個(gè)星期里的每一天排上序號(hào),星期天(Sunday)=1,星期一(Monday)=2,如此類推,到星期六(Saturday)=7。把這些日子的序號(hào)排列在需要減去的天數(shù)前,我們會(huì)得到如下數(shù)據(jù):
if today is |
weekday | subtract |
Monday |
2 | 7 |
Tuesday |
3 | 7 |
Wednesday | 4 | 7 |
Thursday |
5 | 7 |
Friday |
6 | 7 |
Saturday |
7 | 5 |
Sunday |
1 | 6 |
公式如下:
subtract = 7 - 2*(weekday/7) + (weekday-2)/7
記住,這是要獲得“五天前”的日期而需要從今天減去的天數(shù)。在這個(gè)公式里,除法是整數(shù)除法(即下舍入)。請(qǐng)不要問(wèn)我這個(gè)公式是怎么發(fā)現(xiàn)的,反正是試差法的成果。
我們要怎么把這個(gè)公式應(yīng)用到SQL里呢?下面是一個(gè)運(yùn)用MySQL句法的例子:
以下為引用的內(nèi)容:
selectdistinct |
這個(gè)查詢可以獲得“五天前”下訂單而貨還沒(méi)有運(yùn)到的客戶的聯(lián)系方式。
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com