MySQL中查询时间最大的一条记录
在项目中要查询用户最近登录的一条记录的 ip
直接写如下 SQL:
SELECT ip,MAX(act_time) FROM users_login GROUP BY login_id;
但是这样是取不出用户登录记录中时间最大的那个 ip , 仅仅只是查到了最大时间,和 ip 没关系
找了相当多的文章,经过自己测试,发现一个比较好的方式处理这个问题,举例如下:
现在假设有一张数据表 A , 字段和数据如下:
| 姓名(name) | 身份证(唯一标识)(id) | 购买产品(pro) | 价格(price) | 数量(count) | 购买时间(time) |
| 张1 | 111111 | Computer | 1600 | 5 | 2018-03-03 |
| 张1 | 11111 | Phone | 12 | 12 | 2018-03-05 |
| 张2 | 22222 | Pipe | 1 | 234 | 2018-03-04 |
| 张2 | 22222 | Computer | 1600 | 5 | 2018-03-05 |
| 张3 | 33333 | Phone | 12 | 12 | 2018-03-03 |
| 张3 | 33333 | Pipe | 1 | 234 | 2018-03-06 |
| 张3 | 33333 | Computer | 1600 | 5 | 2018-03-09 |
| 张4 | 44444 | Phone | 12 | 12 | 2018-03-09 |
| 张5 | 55555 | Pipe | 1 | 234 | 2018-03-02 |
在这张数据表中,我们需要查询表中每一个用户在最后一次都购买了什么产品以及相关信息
SQL语句如下:
SELECT * from (SELECT * FROM A ORDER BY time) a GROUP BY a.id;
解释:
在这里,我们首先对 A 表进行按照时间的顺序排序,这样我们可以把每个用户最后一次购买记
录排在最上面,排序之后再嵌套一层查询,这一层查询使用 GROUP BY 语句。在使用GROUP
BY 语句的时候,他会按照分组将你排过序的数据的第一条取出来,这样就比较符合条件了,这种
方式在添加索引的情况下效率相当快
MySQL中查询时间最大的一条记录的更多相关文章
- Mysql中 查询慢的 Sql语句的记录查找
Mysql中 查询慢的 Sql语句的记录查找 慢查询日志 slow_query_log,是用来记录查询比较慢的sql语句,通过查询日志来查找哪条sql语句比较慢,这样可以对比较慢的sql可以进行优化. ...
- 如何在MySQL中查询当前数据上一条和下一条的记录
如果ID是主键或者有索引,可以直接查找: 方法一: 查询上一条记录的SQL语句(如果有其他的查询条件记得加上other_conditions以免出现不必要的错误): select * from tab ...
- mysql随机查询符合条件的几条记录
随机查询,方法可以有很多种.比如,查询出所有记录,然后随机从列表中取n条记录.使用程序便可实现.可是程序实现必须查询出所有符合条件的记录(至少是所有符合条件的记录id),然后再随机取出n个id,查询数 ...
- 小安,今天学会了MySQL中查询时间的方法哦
- [django/mysql] 使用distinct在mysql中查询多条不重复记录值的解决办法
前言:不废话.,直接进入正文 正文: 如何使用distinct在mysql中查询多条不重复记录值? 首先,我们必须知道在django中模型执行查询有两种方法: 第一种,使用django给出的api,例 ...
- 如何查找MySQL中查询慢的SQL语句
如何查找MySQL中查询慢的SQL语句 更多 如何在mysql查找效率慢的SQL语句呢?这可能是困然很多人的一个问题,MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow ...
- 如何在MySQL中查询每个分组的前几名【转】
问题 在工作中常会遇到将数据分组排序的问题,如在考试成绩中,找出每个班级的前五名等. 在orcale等数据库中可以使用partition语句来解决,但在mysql中就比较麻烦了.这次翻译的文章就是专门 ...
- mysql 查询每个分组前N条记录
mysql 查询每个分组前N条记录 假设存在表movie, 有字段 id, part(地区), mcount(观看次数) 现查询每个地区观看次数最多的3部movie, 则表 ###id虽未存在gro ...
- sql点滴42—mysql中的时间转换
原文:sql点滴42-mysql中的时间转换 UNIX时间戳转换为日期用函数: FROM_UNIXTIME() select FROM_UNIXTIME(1156219870); 日期转换为UNIX时 ...
随机推荐
- Linux基础命令---文本显示od
od 将指定文件的内容以八进制.十进制.十六进制等编码方式显示.此命令的适用范围:RedHat.RHEL.Ubuntu.CentOS.SUSE.openSUSE.Fedora. 1.语法 ...
- spring 线程安全
http://www.cnblogs.com/doit8791/p/4093808.html 写的真的好
- Lucene 个人领悟 (三)
其实接下来就是贴一下代码,熟悉一下Lucene的正常工作流程,或者说怎么使用这个API,更深层次的东西这篇文章不会讲到. 上一篇文章也说了maven的配置,只要你电脑联网就可以下载下来.我贴一下代码. ...
- 关于Vue中的 render: h => h(App) 具体是什么含义?
render: h => h(App) 是下面内容的缩写: render: function (createElement) { return createElement(App); } 进一步 ...
- bzoj4358 premu
题目链接 莫队算法 没有用线段树,而是看了showson的并查集%%% #include<algorithm> #include<iostream> #include<c ...
- 1、CentOS部署Java开发环境
一.安装jdk jdk下载地址:http://www.Oracle.com/technetwork/java/javase/downloads/jdk-6u31-download-1501634.h ...
- PDF文档导出
代码如下: /// <summary> /// 获取html内容,转成PDF(注册) /// </summary> public void DownloadPDFByHTML( ...
- 使用GoldenGate初始化的两种方式
在使用OGG开始增量数据的实时复制之前,一般需要对当前的存量数据进行初始化,如果是同构数据库,则可以使用数据库自带的工具完成,比如Oracle DB中的rman, expdp/impdp等. 其实og ...
- 给web项目整合富文本编辑器
给jsp页面整合富文本编辑器下载——删除多余的组件——加入到项目中——参照案例来完成整合步骤:1. 解压zip文件,将所有文件复制到Tomcat的webapps/kindeditor目录下. 2. 将 ...
- django模板-通过a标签生成链接并跳转
views.py from django.shortcuts import render from django.http import HttpResponse def index(request) ...