php mysql 如何筛选出每天的最后一条数据呢?

php程序里有这样一句:$logs_result=$database->query("SELECT*FROM`weibo_logs`WHERE`date`BETWEEN'... php 程序里有这样一句:

$logs_result = $database->query("SELECT * FROM `weibo_logs` WHERE `date` BETWEEN '{$date_range_start}' AND DATE_ADD('{$date_range_end}', INTERVAL 1 DAY) AND `weibo_user_id` = '{$source_account->id}' ORDER BY `date` ASC");

我想在不改变原功能的前提下,加一个筛选,选出每天的最后一条数据,以上的代码需要如何修改呢?请指教,感谢!
展开
 我来答
匿名用户
2019-10-18
展开全部
查询今天最后一条数据
SELECT * FROM `weibo_logs` where DATEDIFF( NOW(),date)=0 order by `date` desc limit 1
查询符合条件的weibo_user_id每天的一条数据
SELECT weibo_user_id, DATE_FORMAT(date,'%Y-%m-%d') FROM `text` where 'weibo_user_id'='{$source_account->id}' GROUP BY DATE_FORMAT(date,'%Y-%m-%d')
这样会有排序问题,那么就先排序
SELECT DATE_FORMAT(date,'%Y-%m-%d') as d
FROM (SELECT * FROM `text` ORDER BY date DESC) as s
where 'weibo_user_id'='{$source_account->id}'
GROUP BY DATE_FORMAT(date,'%Y-%m-%d')
知识阅历积累历程

2019-12-26 · 影视爱好者、游戏达人、IT 男
知识阅历积累历程
采纳数:10965 获赞数:6547

向TA提问 私信TA
展开全部
把SQL语句改一下,通过SQL语句查出同一天内最后一条记录:
select * from (select *,FROM_UNIXTIME(date, '%Y-%m-%d') as etime from weibo_logs order by date desc) as b group by b.etime;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式