<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

    1. 明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

      怎么完成日期比較,暨完成顯示5天內,顯示10天內的記錄

      [摘要]前幾天發了一張帖子,就是關于顯示5天內這種日期比較, http://www.oso.com.cn/forum/read.php?theme_id=7459 主要的論點是集中在SELECT somet...

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





      日韩精品一区二区三区高清