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