sql >> Base de Datos >  >> RDS >> Mysql

Cómo obtener el último registro en cada grupo en MySQL

A veces, es posible que deba seleccionar el registro más reciente u obtener el registro más reciente para cada fecha, usuario, identificación o cualquier otro grupo. Aquí está la consulta SQL para obtener el último registro en cada grupo en MySQL, ya que no hay una función integrada para ello. También puede usarlo para seleccionar la última fila de cada grupo en PostgreSQL, SQL Server y Oracle.

Cómo obtener el último registro en cada grupo en MySQL

Estos son los pasos para obtener el último registro en cada grupo en MySQL.

Supongamos que tiene una tabla product_sales(product, order_date,sale) que contiene datos de ventas de varios productos.

mysql> create table product_sales(product varchar(255),order_date date, sale int);

mysql> insert into product_sales(product,order_date, sale)
     values('A','2020-05-01',250),
     ('B','2020-05-01',350),
     ('C','2020-05-01',1250),
     ('A','2020-05-02',450),
     ('B','2020-05-02',650),
     ('C','2020-05-02',1050),
     ('A','2020-05-03',150),
     ('B','2020-05-03',250),
     ('C','2020-05-03',1850);

mysql> select * from product_sales;
+---------+------------+------+
| product | order_date | sale |
+---------+------------+------+
| A       | 2020-05-01 |  250 |
| B       | 2020-05-01 |  350 |
| C       | 2020-05-01 | 1250 |
| A       | 2020-05-02 |  450 |
| B       | 2020-05-02 |  650 |
| C       | 2020-05-02 | 1050 |
| A       | 2020-05-03 |  150 |
| B       | 2020-05-03 |  250 |
| C       | 2020-05-03 | 1850 |
+---------+------------+------+

Lectura adicional:cómo obtener un registro con el valor máximo en MySQL

Digamos que desea obtener el último registro en cada grupo, es decir, para cada producto. Primero usamos GROUP BY para obtener la fecha más reciente de cada grupo.

mysql> select product,max(order_date) from product_sales group by product;
+---------+-----------------+
| product | max(order_date) |
+---------+-----------------+
| A       | 2020-05-03      |
| B       | 2020-05-03      |
| C       | 2020-05-03      |
+---------+-----------------+

Ahora que conocemos la fecha más reciente de cada grupo, unimos este resultado con nuestra tabla original para obtener el último registro por grupo de fechas.

mysql> select product_sales.* from product_sales,
           (select product,max(order_date) as order_date
                from product_sales
                group by product) max_sales
             where product_sales.product=max_sales.product
             and product_sales.order_date=max_sales.order_date;
+---------+------------+------+
| product | order_date | sale |
+---------+------------+------+
| A       | 2020-05-03 |  150 |
| B       | 2020-05-03 |  250 |
| C       | 2020-05-03 | 1850 |
+---------+------------+------+

Lectura adicional:Cómo crear una vista en MySQL

Cómo seleccionar el registro más reciente para cada usuario

De manera similar, puede seleccionar el registro más reciente para cada usuario u obtener el registro más reciente para cada ID. Supongamos que tiene la siguiente tabla user_data(user_id,transaction_date,sale) con datos de transacciones del usuario

mysql> create table user_data(user_id int, transaction_date date, sale int);

mysql> insert into user_data(user_id,transaction_date, sale)
          values('1','2020-05-01',25),
          ('2','2020-05-01',35),
          ('3','2020-05-01',125),
          ('1','2020-05-02',40),
          ('2','2020-05-02',50),
          ('3','2020-05-02',50),
          ('1','2020-05-03',15),
          ('2','2020-05-03',25),
          ('3','2020-05-03',50);


mysql> select * from user_data;
+---------+------------------+------+
| user_id | transaction_date | sale |
+---------+------------------+------+
|       1 | 2020-05-01       |   25 |
|       2 | 2020-05-01       |   35 |
|       3 | 2020-05-01       |  125 |
|       1 | 2020-05-02       |   40 |
|       2 | 2020-05-02       |   50 |
|       3 | 2020-05-02       |   50 |
|       1 | 2020-05-03       |   15 |
|       2 | 2020-05-03       |   25 |
|       3 | 2020-05-03       |   50 |
+---------+------------------+------+

Lectura adicional:Cómo obtener nuevos usuarios por día en MySQL

Primero, obtenemos la fecha más reciente para cada ID de usuario usando GROUP BY.

mysql> select user_id,max(transaction_date) from user_data group by user_id;
+---------+-----------------------+
| user_id | max(transaction_date) |
+---------+-----------------------+
|       1 | 2020-05-03            |
|       2 | 2020-05-03            |
|       3 | 2020-05-03            |
+---------+-----------------------+

Ahora que conocemos la fecha más reciente de cada ID de usuario, unimos este resultado con nuestra tabla original para obtener el registro más reciente por grupo de usuarios.

mysql> select user_data.* from user_data,
                (select user_id,max(transaction_date) as transaction_date
                     from user_data
                     group by user_id) max_user
                  where user_data.user_id=max_user.user_id
                  and user_data.transaction_date=max_user.transaction_date;
+---------+------------------+------+
| user_id | transaction_date | sale |
+---------+------------------+------+
|       1 | 2020-05-03       |   15 |
|       2 | 2020-05-03       |   25 |
|       3 | 2020-05-03       |   50 |
+---------+------------------+------+

Con suerte, puede obtener el último registro en cada grupo en MySQL