MySQL GROUP BY子句是否可以像DISTINCT子句一样使用多列?
是的,可以像使用DISTINCT子句一样使用MySQL的GROUP BY子句,可以考虑以下示例,其中第一个查询使用DISTINCT子句,第二个查询使用GROUP BY子句,在名为’testing’的表格上的’fname’和’Lname’列上进行操作:
mysql> Select * from testing;
+------+---------+---------+
| id | fname | Lname |
+------+---------+---------+
| 200 | Raman | Kumar |
| 201 | Sahil | Bhalla |
| 202 | Gaurav | NULL |
| 203 | Aarav | NULL |
| 204 | Harshit | Khurana |
| 205 | Rahul | NULL |
| 206 | Piyush | Kohli |
| 207 | Lovkesh | NULL |
| 208 | Gaurav | Kumar |
| 209 | Raman | Kumar |
+------+---------+---------+
10 rows in set (0.00 sec)
mysql> Select DISTINCT FNAME,LNAME from testing;
+---------+---------+
| FNAME | LNAME |
+---------+---------+
| Raman | Kumar |
| Sahil | Bhalla |
| Gaurav | NULL |
| Aarav | NULL |
| Harshit | Khurana |
| Rahul | NULL |
| Piyush | Kohli |
| Lovkesh | NULL |
| Gaurav | Kumar |
+---------+---------+
9 rows in set (0.00 sec)
mysql> Select Fname, LNAME from testing GROUP BY Fname,Lname;
+---------+---------+
| Fname | LNAME |
+---------+---------+
| Aarav | NULL |
| Gaurav | NULL |
| Gaurav | Kumar |
| Harshit | Khurana |
| Lovkesh | NULL |
| Piyush | Kohli |
| Rahul | NULL |
| Raman | Kumar |
| Sahil | Bhalla |
+---------+---------+
9 rows in set (0.00 sec)
唯一的区别是使用GROUP BY子句的MySQL查询返回的结果集是排过序的,而使用DISTICT子句的查询结果集则没有排序。
阅读更多:MySQL 教程
极客教程