前幾天發了一張帖子,就是關於顯示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函數實現的效率高