A veces, es posible que necesite obtener el número de fila en MySQL para informes y análisis. El número de fila es muy útil para clasificar y clasificar datos. También es útil para filtrar datos según el valor del número de fila. En este artículo, veremos cómo obtener row_number en MySQL.
Cómo obtener el número de fila en MySQL
La función Row_number() está disponible desde MySQL 8.0.
Esta es la sintaxis de row_number() sintaxis. Tenga en cuenta que la cláusula PARTITION BY es opcional.
ROW_NUMBER() OVER ( PARTITION BY <expression(s)> ORDER BY <expression(s)> [ASC|DESC])
Digamos que tiene las siguientes ventas mesa.
+------+------------+--------+ | id | order_date | amount | +------+------------+--------+ | 1 | 2021-01-01 | 200 | | 2 | 2021-01-02 | 250 | | 3 | 2021-01-03 | 220 | | 4 | 2021-01-04 | 230 | | 5 | 2021-01-05 | 210 | | 6 | 2021-01-06 | 100 | | 7 | 2021-01-07 | 120 | | 8 | 2021-01-08 | 150 | | 9 | 2021-01-09 | 180 | | 10 | 2021-01-10 | 200 | +------+------------+--------+
Este es un ejemplo del uso de row_number función para clasificar las filas en orden descendente de cantidad columna.
mysql> select row_number() over ( order by amount desc) row_num, amount from sales order by amount desc; +---------+--------+ | row_num | amount | +---------+--------+ | 1 | 250 | | 2 | 230 | | 3 | 220 | | 4 | 210 | | 5 | 200 | | 6 | 200 | | 7 | 180 | | 8 | 150 | | 9 | 120 | | 10 | 100 | +---------+--------+
En la consulta anterior, tratamos toda la tabla como una sola partición y no proporcionamos la cláusula PARTITION BY. También ordenamos estas filas en orden descendente por columna de cantidad y usamos row_number() función para clasificar estas filas.
Sin embargo, si está utilizando MySQL <8.0, estos son los pasos para obtener row_number en MySQL.
mysql> SELECT t.*, @rownum := @rownum + 1 AS rank FROM sales t, (SELECT @rownum := 0) r order by amount desc; +------+---------------------+--------+------+ | id | order_date | amount | rank | +------+---------------------+--------+------+ | 1 | 2021-02-02 08:15:00 | 250 | 1 | | 10 | 2021-02-02 11:15:00 | 250 | 2 | | 5 | 2021-02-02 09:30:00 | 250 | 3 | | 9 | 2021-02-02 10:45:00 | 200 | 4 | | 12 | 2021-02-02 11:45:00 | 200 | 5 | | 6 | 2021-02-02 09:45:00 | 200 | 6 | | 2 | 2021-02-02 08:30:00 | 200 | 7 | | 7 | 2021-02-02 10:15:00 | 180 | 8 | | 3 | 2021-02-02 08:55:00 | 150 | 9 | | 11 | 2021-02-02 11:30:00 | 150 | 10 | | 4 | 2021-02-02 09:15:00 | 125 | 11 | | 8 | 2021-02-02 10:30:00 | 125 | 12 | +------+---------------------+--------+------+
En la consulta SQL anterior, usamos una variable temporal rownum para almacenar el número de fila. Cuando MySQL recorre secuencialmente las filas, asigna rownum a cada fila de manera incremental.
¿Necesita una herramienta de informes para MySQL? Ubiq facilita la visualización de datos en minutos y el monitoreo en paneles en tiempo real. ¡Pruébalo hoy!