如何實現日期比較,暨實現顯示5天內,顯示10天內的記錄 - 中國WEB開發者網絡 (http://www.webasp.net) -- 技術教程 (http://www.webasp.net/article/) --- 如何實現日期比較,暨實現顯示5天內,顯示10天內的記錄 (http://www.webasp.net/article/14/13898.htm) |
| -- 作者:未知 -- 發佈日期: 2004-10-14 |
| 前幾天發了一張帖子,就是關於顯示5天內這種日期比較,
http://www.oso.com.cn/forum/read.php?theme_id=7459 主要的論點是集中在SELECT something FROM table WHERE TO_DAYS(NOW()) - TO_DAYS(date_col) < = 5; 上,我試驗了半天,結果還是出錯,今天看了MYSQL的函數,終於出來了結果,不敢獨享,貼出來供大家研究,(雖然技術含量不高,別扔我柿子就行,呵呵) MYSQL的TO_DAYS(DATE)函數是這樣說明的: 傳回DATE到公元0年的總日數,我測試了一下 mysql>select to_days(now(0)); +--------------------------+ | TO_DAYS(NOW()) | +--------------------------+ | 730839 | +--------------------------+ 出來的是當前時間距離公元0年的總日數,接著我試著用上面的語句測試; mysql>select TO_DAYS(NOW()) - TO_DAYS(date_col) < = 5; 出現結果: ERROR 1054:Unknown column 'date_col' in 'field first' 此路不通了,我就試著直接把5代到date_col裡去 mysql>select to_days(now()) - to_days(5); 出現結果: +---------------------------+ |to_days(now()) - to_days(5)| +---------------------------+ | NULL | +---------------------------+ 啊?不會吧?這樣也不行啊? 我接著試命令 mysql>select 。。。。 突然猛的想到,嘿嘿,to_days(now())出來的是整數,我直接跟整數運算就行了,何必再to_days(date)呢?馬上試驗 mysql>select to_days(now()) - 5; +--------------------------+ | to_days(now()) -5 | +--------------------------+ | 730834 | +--------------------------+ OK,萬歲,終於得到了我想要的結果,呵呵 下面就是在PHP代碼中用SELECT 查詢了 我存數據庫向來的習慣就是DATEANDTIME用NOW()直接賦值,顯示的時候不用格式化,直接取出來就能用, 下面是我的一個庫的部分結構 CREATE TABLE infomess ( infoid int(11) NOT NULL auto_increment, topic varchar(255) NOT NULL, …… email varchar(50), dateandtime datetime DEFAULT '0000-00-00 00:00:00' NOT NULL, PRIMARY KEY (infoid) ); 這裡的DATEANDTIME是標準的日期格式,然後我要查詢5天內的記錄,下面是SQL查詢語句 $sql="select * from infomess where to_days(dateandtime) >= (to_days(now()) - 5) order by infoid desc limit $offset,$psize"; 就要一個where to_days(dateandtime) >= (to_days(now()) - 5)就夠了 後面的是另外的,這裡的5可以設為一個變量 where to_days(dateandtime) >= (to_days(now()) - $limitdays) 然後$limitdays可以用GET方式傳遞(多數是有GET方式傳遞) 在你的PHP後面跟上?limitdays=5就行了 顯示10天內也一樣,$limitdasy改成10就行了 以上是利用MYSQL函數得到這樣的結果,以上的結果都經過測試,因為時間匆忙,如果代碼有什麼問題,請跟帖提出,謝謝 還有朋友說利用UNIX戳記來得到這樣的結果,請問哪位寫過這樣的代碼,貼點出來,供大家參考比較,也可以測試判斷一下PHP函數還是MYSQL函數實現的效率高 |
| webasp.net |