Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

MySQL에 그룹 결과를 표시하고 목록에 표시하시겠습니까?

<시간/>

이를 위해 ORDER BY −

와 함께 GROUP BY를 사용하십시오.
select yourColumnName,count(*) as anyAliasName from yourTableName group by yourColumnName order by yourColumnName;

테이블을 만들어 봅시다 -

mysql> create table demo7
−> (
−> id int NOT NULL AUTO_INCREMENT,
−> first_name varchar(50)
−> ,
−> primary key(id)
−> );
Query OK, 0 rows affected (1.22 sec)

insert 명령을 사용하여 일부 레코드를 테이블에 삽입하십시오 -

mysql> insert into demo7(first_name) values('John');
Query OK, 1 row affected (0.09 sec)
mysql> insert into demo7(first_name) values('David');
Query OK, 1 row affected (0.22 sec)
mysql> insert into demo7(first_name) values('John');
Query OK, 1 row affected (0.07 sec)
mysql> insert into demo7(first_name) values('Bob');
Query OK, 1 row affected (0.27 sec)
mysql> insert into demo7(first_name) values('David');
Query OK, 1 row affected (0.11 sec)
mysql> insert into demo7(first_name) values('David');
Query OK, 1 row affected (0.09 sec)
mysql> insert into demo7(first_name) values('John');
Query OK, 1 row affected (0.26 sec)
mysql> insert into demo7(first_name) values('John');
Query OK, 1 row affected (0.09 sec)

select 문을 사용하여 테이블의 레코드 표시 -

mysql> select *from demo7;

이것은 다음과 같은 출력을 생성합니다 -

+----+------------+
| id | first_name |
+----+------------+
|  1 | John       |
|  2 | David      |
|  3 | John       |
|  4 | Bob        |
|  5 | David      |
|  6 | David      |
|  7 | John       |
|  8 | John       |
+----+------------+
8 rows in set (0.00 sec)

다음은 MySQL에서 결과를 그룹화하고 목록에 표시하는 쿼리입니다 -

mysql> select first_name,count(*) as frequency from demo7 group by first_name order by first_name;

이것은 다음과 같은 출력을 생성합니다 -

+------------+-----------+
| first_name | frequency |
+------------+-----------+
| Bob        |         1 |
| David      |         3 |
| John       |         4 |
+------------+-----------+
3 rows in set (0.00 sec)