我们可以像使用 MySQL DISTINCT 子句一样对多个列使用 MySQL GROUP BY 子句吗?

我们可以像使用 MySQL DISTINCT 子句一样对多个列使用 MySQL GROUP BY 子句吗?

是的,可以使用MySQL的GROUP BY子句来对多个列进行分组,就像我们可以使用MySQL的DISTINCT子句一样。考虑以下示例,在第一个查询中我们使用了DISTINCT子句,在名为‘testing’的表的‘fname’和‘Lname’列上使用了GROUP BY子句的第二个查询。

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查询返回的结果集是排序的,而使用DISTINCT子句的MySQL查询返回的结果集则没有排序。

以上就是我们可以像使用 MySQL DISTINCT 子句一样对多个列使用 MySQL GROUP BY 子句吗?的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

上一篇 如何处理C++开发中的网络连接问题
下一篇 C++编译错误:无法使用链接指定的对象文件,应该如何解决?