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’;
都不對,結果集都是空的
問題解答
回答1:參考文章:MySQL時間處理相關函數
WHERE DATE(created_at) = ’2017-06-29’
或是
WHERE created_at LIKE ’2017-06-29%’
回答2:datetime默認格式’2017-06-29 00:00:00’ 如果你的數據這一天確實有數據的話第二條是會有結果的,所以首先你要看一下是不是表中有這一天的數據并且你的數據格式是什么樣的
PS:取某一天的數據可以created_at like ’yyyy-mm-dd%’或者就是你第二種寫法,date(created_at)、left(created_at)也可以取到當天的日期,但是都不會走索引,效率很差
回答3:我的可以,可能是你的表或者字段錯了,或者確實沒有結果。。條件是沒問題的
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);
意思就是查詢大于等于今天零時小于明天零時的時間
回答5:第一行不對, 因為datetime和你條件里面的格式不一樣.
第二行是對的. 結果也是對的, 因為確實沒數據.
相關文章:
1. javascript - js 有什么優雅的辦法實現在同時打開的兩個標簽頁間相互通信?2. java - 新手做一個安卓視頻播放器,想實現一個進度條,按鈕那種在視頻下方懸浮的功能,不知道思路!3. android - 目前有哪些用Vue.js開發移動App的方案?4. html5和Flash對抗是什么情況?5. 想找個php大神仿個網站。6. javascript - 一個抽獎的效果(如圖)?7. javascript - 怎樣限制同一個瀏覽器不能登錄兩個賬號8. css3 - Typecho 后臺部分表單按鈕在 Chrome 下出現靈異動畫問題,求解決9. java - android代碼重構:如何把app設置里的頭像UI做成通用的?10. javascript - jquery怎么給select option一個點擊時觸發的事件,如圖 如果選擇自定義觸發一個時間?
