Computer >> Máy Tính >  >> Lập trình >> MySQL

Đếm nhiều hàng và hiển thị kết quả trong các cột khác nhau (và một hàng duy nhất) với MySQL

Đầu tiên chúng ta hãy tạo một bảng -

mysql> create table DemoTable1452
   -> (
   -> FavouriteColor varchar(50)
   -> );
Query OK, 0 rows affected (2.42 sec)

Chèn một số bản ghi vào bảng bằng lệnh chèn -

mysql> insert into DemoTable1452 values('Red');
Query OK, 1 row affected (0.31 sec)
mysql> insert into DemoTable1452 values('Yellow');
Query OK, 1 row affected (0.20 sec)
mysql> insert into DemoTable1452 values('Yellow');
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable1452 values('Yellow');
Query OK, 1 row affected (0.23 sec)
mysql> insert into DemoTable1452 values('Blue');
Query OK, 1 row affected (0.42 sec)
mysql> insert into DemoTable1452 values('Blue');
Query OK, 1 row affected (0.33 sec)
mysql> insert into DemoTable1452 values('Red');
Query OK, 1 row affected (0.29 sec)

Hiển thị tất cả các bản ghi từ bảng bằng câu lệnh select -

mysql> select * from DemoTable1452;

Điều này sẽ tạo ra kết quả sau -

+----------------+
| FavouriteColor |
+----------------+
| Red            |
| Yellow         |
| Yellow         |
| Yellow         |
| Blue           |
| Blue           |
| Red            |
+----------------+
7 rows in set (0.00 sec)

Sau đây là truy vấn để đếm nhiều hàng và hiển thị kết quả trong các cột khác nhau -

mysql> select sum(FavouriteColor='Red') as NumberOfRedColor,
   -> sum(FavouriteColor='Yellow') as NumberOfYellowColor,
   -> sum(FavouriteColor='Blue') as NumberOfBlueColor
   -> from DemoTable1452;

Điều này sẽ tạo ra kết quả sau -

+------------------+---------------------+-------------------+
| NumberOfRedColor | NumberOfYellowColor | NumberOfBlueColor |
+------------------+---------------------+-------------------+
|                2 |                   3 |                 2 |
+------------------+---------------------+-------------------+
1 row in set (0.27 sec)