第一遍看GROUP BY的介紹時,沒看懂。
SQLite 的 GROUP BY 子句用於與 SELECT 語句一起使用,來對相同的數據進行分組。在 SELECT 語句中,GROUP BY 子句放在 WHERE 子句之后,放在 ORDER BY 子句之前。
假設有如下表:
sqlite> select * from company; ID NAME AGE ADDRESS SALARY ---------- ---------- ---------- ---------- ---------- 1 Paul 32 California 20000.0 2 Allen 25 Texas 15000.0 3 Teddy 23 Norway 20000.0 4 Mark 25 Rich-Mond 65000.0 5 David 27 Texas 85000.0 6 Kim 22 Texas 45000.0 7 James 24 Houston 10000.0 8 Paul 32 California 20000.0 9 James 44 Texas 5000.0 10 James 45 Texas 5000.0
假設需要統計每個人的薪水,很顯然,只要把每個人的薪水統計一下即可。那么首先就需要確定哪幾條記錄是同一個人的。上表中,有2條記錄為Paul,3條記錄為James,仔細觀察可以看到,Paul的地址和年齡是一樣的,說明是同一個人,而每個James要么年齡不同,要么地址不同,可以判斷他們不是同一個人,需要分開來統計。有了這些前提描述,再看看下面的sql語句和輸出:
sqlite> select id,name,age,address,sum(salary) from company group by name,age,address; ID NAME AGE ADDRESS sum(salary) ---------- ---------- ---------- ---------- ----------- 2 Allen 25 Texas 15000.0 5 David 27 Texas 85000.0 7 James 24 Houston 10000.0 9 James 44 Norway 5000.0 10 James 45 Texas 5000.0 6 Kim 22 Texas 45000.0 4 Mark 25 Rich-Mond 65000.0 8 Paul 32 California 40000.0 3 Teddy 23 Norway 20000.0
可以看到Paul薪水數據被合並,James未合並,因為他們不是同一個人。關鍵在於"group by name, age, address",意思是將name, age ,address均相同的項合並為一項
