程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 如何實現日期比較,暨

如何實現日期比較,暨

編輯:關於PHP編程

前幾天發了一張帖子,就是關於顯示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查詢語句

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved