在MySQL中group by 是什么意思



mysql語法中group by是什么意思?

在百度中搜索半天,最后找到一篇解釋比較好的(不是博文,是百度知道,很郁悶那么多網友怎么就沒人解釋的清楚),鏈接如下:

http://zhidao.baidu.com/question/495569434771073124.html

按照上面所說的數據庫,我自己建了一個stu,操作如下:

1.

mysql> select * from stu;
+------+--------+-------+
| name | course | score |
+------+--------+-------+
| 張三     | java   |    90 |
| 張三     | c#     |    98 |
| 李四     | java   |    89 |
| 李四     | c#     |    62 |
| 李四     | c++    |    80 |
+------+--------+-------+

按照網友說的如下操作,但是在select查詢語句中多加一列course,因為以course來進行分組的,這樣顯示的效果會非常明顯。

2.

mysql> select course,sum(score) from stu group by course;
+--------+------------+
| course | sum(score) |
+--------+------------+
| c#     |        160 |
| c++    |         80 |
| java   |        179 |
+--------+------------+

再多來個實例:

3.

mysql> select name,sum(score) from stu group by name;
+------+------------+
| name | sum(score) |
+------+------------+
| 張三     |        188 |
| 李四     |        231 |
+------+------------+

是不是霍然開朗了

下面我的理解如下:

group by確實是分組,是把group by后面帶的列元素名內容相等的進行分組(這是核心),然后前面的函數操作就是對這些分組進行操作,如按照第2步中的實例,原來5條記錄,現在通過course來分組了一下,現在成了3組,然后sum的操作就是對每一組進行求和,這樣顯示出的結果就是第二步的結果了,同理第3步一樣。



免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM