首頁  >  問答  >  主體

MySQL 如何從 datetime 類型的欄位選擇 date

有個欄位created_at是 datetime 類型,如何選擇特定日期的資料?

SELECT * FROM data WHERE created_at = '2017-06-29';
SELECT * FROM data WHERE created_at BETWEEN '2017-06-29 00:00:00' AND '2017-06-29 23:59:59';

都不對,結果集都是空的

某草草某草草2668 天前956

全部回覆(5)我來回復

  • 曾经蜡笔没有小新

    曾经蜡笔没有小新2017-06-30 09:55:42

    參考文章:MySQL時間處理相關函數

    WHERE DATE(created_at) = '2017-06-29'

    或是

    WHERE created_at LIKE '2017-06-29%'

    回覆
    0
  • 習慣沉默

    習慣沉默2017-06-30 09:55:42

    datetime預設格式'2017-06-29 00:00:00' 如果你的數據這一天確實有數據的話第二條是會有結果的,所以首先你要看一下是不是表中有這一天的數據而你的資料格式是什麼樣的

    PS:取某一天的資料可以created_at like 'yyyy-mm-dd%'或就是你第二種寫法,date(created_at)、left(created_at)也可以取到當天的日期,但是都不會走索引,效率很差

    回覆
    0
  • 仅有的幸福

    仅有的幸福2017-06-30 09:55:42

    我的可以,可能是你的表格或欄位錯了,或者確實沒有結果。 。條件是沒問題的

    回覆
    0
  • 高洛峰

    高洛峰2017-06-30 09:55:42

    select * from data d WHERE d.created_at >= curdate()
    and d.created_at < DATE_ADD(STR_TO_DATE(curdate(), '%Y-%m-%d'), INTERVAL 1 DAY);

    意思就是查詢大於等於今天零時小於明天零時的時間

    回覆
    0
  • 黄舟

    黄舟2017-06-30 09:55:42

    第一行不對, 因為datetime跟你條件裡面的格式不一樣.

    第二行是對的.
    結果也是對的, 因為確實沒數據.

    回覆
    0
  • 取消回覆