要求:查詢出2門及2門以上不及格者的平均成績。
經常會用兩種查詢語句有兩種:
1. select name,sum(score < 60) ,avg(score) from result group by name having sum(score<60) >=2;
再看
算你擁有動物的總數目與“在pet表中有多少行?”是同樣的問題,因為每個寵物有一個記錄。COUNT(*)函數計算行數,所以計算動物數目的查詢應為:
代碼如下 復制代碼 mysql> SELECT COUNT(*) FROM pet;在前面,你檢索了擁有寵物的人的名字。如果你想要知道每個主人有多少寵物,你可以使用COUNT( )函數:
代碼如下 復制代碼 mysql> SELECT owner, COUNT(*) FROM pet GROUP BY owner;注 意,使用GROUP BY對每個owner的所有記錄分組,沒有它,你會得到錯誤消息:
代碼如下 復制代碼 mysql> SELECT owner, COUNT(*) FROM pet;COUNT( )和GROUP BY以各種方式分類你的數據。下列例子顯示出進行動物普查操作的不同方式。
每種動物的數量:
代碼如下 復制代碼 mysql> SELECT species, COUNT(*) FROM pet GROUP BY species;每種性別的動物數量:
代碼如下 復制代碼 mysql> SELECT sex, COUNT(*) FROM pet GROUP BY sex;(在這個輸 出中,NULL表示“未知性別”。)
按種類和性別組合的動物數量:
代碼如下 復制代碼 mysql> SELECT species, sex, COUNT(*) FROM pet GROUP BY species, sex;若 使用COUNT( ),你不必檢索整個表。例如, 前面的查詢,當只對狗和貓進行時,應為:
代碼如下 復制代碼 mysql> SELECT species, sex, COUNT(*) FROM pet或, 如果你僅需要知道已知性別的按性別的動物數目:
代碼如下 復制代碼mysql> SELECT species, sex, COUNT(*) FROM pet
-> WHERE sex IS NOT NULL
-> GROUP BY species, sex;
+---------+------+----------+
| species | sex | COUNT(*) |
+---------+------+----------+
| bird | f | 1 |
| cat | f | 1 |
| cat | m | 1 |
| dog | f | 1 |
| dog | m | 2 |
| hamster | f | 1 |
| snake | m | 1 |
+---------+------+----------+
mysql sum
代碼如下 復制代碼2.select name ,count((score<60)!=0) as a,avg(score) from result group by name having a >=2;