如何實現日期比較,暨實現顯示5天內,顯示10天內的記錄


前幾天發瞭一張帖子,就是關於顯示5天內這種日期比較,

https://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函數實現的效率高

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。