MySQL 如何从 datetime 类型的字段选择 date
某草草
某草草 2017-06-30 09:53:42
[MySQL讨论组]

有个字段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';

都不对,结果集都是空的

某草草
某草草

全部回复(5)
曾经蜡笔没有小新

参考文章:MySQL时间处理相关函数

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

或是

WHERE created_at LIKE '2017-06-29%'

習慣沉默

datetime默认格式'2017-06-29 00:00:00' 如果你的数据这一天确实有数据的话第二条是会有结果的,所以首先你要看一下是不是表中有这一天的数据并且你的数据格式是什么样的

PS:取某一天的数据可以created_at like 'yyyy-mm-dd%'或者就是你第二种写法,date(created_at)、left(created_at)也可以取到当天的日期,但是都不会走索引,效率很差

仅有的幸福

我的可以,可能是你的表或者字段错了,或者确实没有结果。。条件是没问题的

高洛峰
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);

意思就是查询大于等于今天零时小于明天零时的时间

黄舟

第一行不对, 因为datetime和你条件里面的格式不一样.

第二行是对的.
结果也是对的, 因为确实没数据.

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号