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

Làm cách nào để NHÓM THEO trong một truy vấn chọn trên các giá trị dương hoặc âm?

Sau đây là cú pháp để GROUP BY trong một truy vấn chọn trên các giá trị dương hoặc âm:

select *from yourTableName group by -yourColumnName;

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

mysql> create table DemoTable (Value int);
Query OK, 0 rows affected (0.60 sec)

Sau đây là truy vấn để chèn một số bản ghi trong bảng bằng cách sử dụng lệnh insert:

mysql> insert into DemoTable values(-10);
Query OK, 1 row affected (0.20 sec)
mysql> insert into DemoTable values(-20);
Query OK, 1 row affected (0.10 sec)
mysql> insert into DemoTable values(20);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable values(10);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable values(-10);
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.16 sec)
mysql> insert into DemoTable values(-30);
Query OK, 1 row affected (0.07 sec)
mysql> insert into DemoTable values(30);
Query OK, 1 row affected (0.12 sec)

Sau đây là truy vấn để hiển thị các bản ghi từ bảng bằng lệnh select:

mysql> select *from DemoTable;

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

+-------+
| Value |
+-------+
|   -10 |
|   -20 |
|    20 |
|    10 |
|   -10 |
|   -10 |
|   -20 |
|   -30 |
|    30 |
+-------+
9 rows in set (0.00 sec)

Sau đây là truy vấn để nhóm theo các giá trị âm và dương:

mysql> select *from DemoTable group by -Value;

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

+-------+
| Value |
+-------+
|   -10 |
|   -20 |
|    20 |
|    10 |
|   -30 |
|    30 |
+-------+
6 rows in set (0.00 sec)