获取MySQL的表中每个userid最后一条记录的方法
2015-05-09 11:55
633 查看
如下表:
CREATE TABLE `t1` ( `userid` int(11) DEFAULT NULL, `atime` datetime DEFAULT NULL, KEY `idx_userid` (`userid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; CREATE TABLE `t1` ( `userid` int(11) DEFAULT NULL, `atime` datetime DEFAULT NULL, KEY `idx_userid` (`userid`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
数据如下:
MySQL> select * from t1; +--------+---------------------+ | userid | atime | +--------+---------------------+ | 1 | 2013-08-12 11:05:25 | | 2 | 2013-08-12 11:05:29 | | 3 | 2013-08-12 11:05:32 | | 5 | 2013-08-12 11:05:34 | | 1 | 2013-08-12 11:05:40 | | 2 | 2013-08-12 11:05:43 | | 3 | 2013-08-12 11:05:48 | | 5 | 2013-08-12 11:06:03 | +--------+---------------------+ 8 rows in set (0.00 sec) MySQL> select * from t1; +--------+---------------------+ | userid | atime | +--------+---------------------+ | 1 | 2013-08-12 11:05:25 | | 2 | 2013-08-12 11:05:29 | | 3 | 2013-08-12 11:05:32 | | 5 | 2013-08-12 11:05:34 | | 1 | 2013-08-12 11:05:40 | | 2 | 2013-08-12 11:05:43 | | 3 | 2013-08-12 11:05:48 | | 5 | 2013-08-12 11:06:03 | +--------+---------------------+ 8 rows in set (0.00 sec)
其中userid不唯一,要求取表中每个userid对应的时间离现在最近的一条记录.初看到一个这条件一般都会想到借用临时表及添加主建借助于join操作之类的.
给一个简方法:
MySQL> select userid,substring_index(group_concat(atime order by atime desc),",",1) as atime from t1 group by userid; +--------+---------------------+ | userid | atime | +--------+---------------------+ | 1 | 2013-08-12 11:05:40 | | 2 | 2013-08-12 11:05:43 | | 3 | 2013-08-12 11:05:48 | | 5 | 2013-08-12 11:06:03 | +--------+---------------------+ 4 rows in set (0.03 sec) MySQL> select userid,substring_index(group_concat(atime order by atime desc),",",1) as atime from t1 group by userid; +--------+---------------------+ | userid | atime | +--------+---------------------+ | 1 | 2013-08-12 11:05:40 | | 2 | 2013-08-12 11:05:43 | | 3 | 2013-08-12 11:05:48 | | 5 | 2013-08-12 11:06:03 | +--------+---------------------+ 4 rows in set (0.03 sec)
Good luck!
您可能感兴趣的文章:
相关文章推荐
- 获取MySQL的表中每个userid最后一条记录的方法
- last_insert_id()获取mysql最后一条记录ID
- Java获取最后插入MySQL记录的自增ID值方法
- 有两个表,关联字段是userid,每个用户下面有多条记录,怎么列出所有用户的最后一条记录!!!
- MYSQL中获取得最后一条记录的语句
- Java获取最后插入MySQL记录的自增ID值的3种方法
- MYSQL中获取得最后一条记录的语句
- mysql随机获取一条或多条记录常见2种方法分析
- MYSQL中如何获取最后一条记录?
- Java获取最后插入MySQL记录的自增ID值的3种方法
- MYSQL中获取得最后一条记录的语句
- mysql获取group by的总记录行数方法
- mongodb 随机获取一条记录的方法
- mysql 重复记录只选取最后一条
- mysql 实现行号的方法——如何获取当前记录所在行号
- PHP获取MySql新增记录ID值的方法
- [MySQL]学习笔记- 用户行为表中,查询每个人的一条最新行为(分组 排序 取时间最大的一条记录)
- 获取分组后取某字段最大的一条记录(求每个类别中最大的值的列表)
- mysql获取group by的总记录行数方法
- mongodb 随机获取一条记录的方法