查询仅从所有用户获取最后一条消息 [英] query to get last message only from all users

查看:52
本文介绍了查询仅从所有用户获取最后一条消息的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要编写一个查询来使用 mysql 表从两列中检索值

I need to write a query to retrieve values from two columns using mysql table

我的表具有以下结构

| ID | to_user_id | from_user_id |  message  |        datetime     | 
| 1  |     21     |      07      |    hi     | 2012-05-10 04:13:01 | 
| 2  |     07     |      21      |   hello   | 2012-05-10 04:17:51 | 
| 3  |     21     |      11      | what's up | 2012-05-10 04:21:51 |
| 4  |     21     |      02      |  hi dude  | 2012-05-10 04:43:51 |

我想写一个查询来只获取来自所有 from_user_id 的最新消息

I want to write a query to get only latest message from all from_user_id's

我会尝试

$query="select * from messages WHERE datetime = (SELECT MAX(datetime) FROM messages)";

但显示错误

'where 子句'中的未知列'datetime'

Unknown column 'datetime' in 'where clause'

推荐答案

你也可以试试:

select a.from_user_id, a.message
from table1 a
WHERE a.datetime = (SELECT MAX(datetime) FROM table1 x WHERE x.from_user_id = a.from_user_id)

这篇关于查询仅从所有用户获取最后一条消息的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆