Cuente filas que tengan tres o más filas con un determinado valor en una tabla MySQL
Primero creemos una tabla:
mysql> create table DemoTable
-> (
-> UserId int
-> );
Query OK, 0 rows affected (0.48 sec)
Inserte algunos registros en la tabla usando el comando insertar:
mysql> insert into DemoTable values(10);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable values(20);
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable values(30);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable values(10);
Query OK, 1 row affected (0.14 sec)
mysql> insert into DemoTable values(10);
Query OK, 1 row affected (0.09 sec)
mysql> insert into DemoTable values(20);
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable values(30);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable values(10);
Query OK, 1 row affected (0.19 sec)
mysql> insert into DemoTable values(20);
Query OK, 1 row affected (0.17 sec)
mysql> insert into DemoTable values(20);
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable values(40);
Query OK, 1 row affected (0.21 sec)
Muestre todos los registros de la tabla usando la declaración de selección:
mysql> select *from DemoTable;
Producción
+----------+
| UserId |
+----------+
| 10 |
| 20 |
| 30 |
| 10 |
| 10 |
| 20 |
| 30 |
| 10 |
| 20 |
| 20 |
| 40 |
+----------+
11 rows in set (0.00 sec)
La siguiente es la consulta para contar las filas que tienen 3 o más filas con un valor determinado en una tabla MySQL:
mysql> select count(*)
-> from (select UserId, count(*) as total
-> from DemoTable group by UserId
-> )tbl
-> where total >=3;
Esto producirá el siguiente resultado, es decir, los valores 10 y 20 aparecen tres o más veces. Por lo tanto, el recuento es para 2 valores:
Producción
+----------+
| count(*) |
+----------+
| 2 |
+----------+
1 row in set (0.01 sec)