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. dockerfile - 我用docker build的时候出现下边问题 麻烦帮我看一下2. 请问怎么改变超链接字体的颜色?3. Mongodb web连接28017后,提示登录的用户名密码在 db那里预设置4. java编程思想第4版中文版的几处谬误?5. java - 做数据库向手机端的推送要系统地学习哪些知识?求大神指点,谢谢!6. docker-machine添加一个已有的docker主机问题7. 为什么我ping不通我的docker容器呢???8. 急急急!!!求大神解答网站评论问题,有大神帮帮小弟吗9. linux - 如何编写expect脚本自动导入mysql数据库10. 在add.php中提交数据库已有的姓名,没有提示框
![dockerfile - 我用docker build的时候出现下边问题 麻烦帮我看一下](http://www.haobala.com/attached/image/news/202311/1028095cc6.png)