sqlite sql語句關鍵字GROUP BY的理解


  第一遍看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均相同的項合並為一項

 


免責聲明!

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



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