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. angular.js - 如何通俗易懂的解釋“依賴注入”?2. 我在centos容器里安裝docker,也就是在容器里安裝容器,報錯了?3. 老哥們求助啊4. 我的html頁面一提交,網頁便顯示出了我的php代碼,求問是什么原因?5. django - 后臺返回的json數據經過Base64加密,獲取時用python如何解密~!6. html5 - angularjs中外部模版加載無法使用7. css3 - 請問一下在移動端CSS布局布局中通常需要用到哪些元素,屬性?8. tp6表單令牌9. node.js - node 客戶端socket一直報錯Error: read ECONNRESET,用php的socket沒問題哈。。10. ubuntu PPA 更新老是不成功該怎么辦
