MySQL實戰3 分組查詢和連接查詢

MySQL實戰 目錄

1.分組查詢

分組函數和前面講的函數不同在于,前面的對內容本身的處理,而分組函數的主要功能是統計。

主要講的是分組函數:sum , avg, max, min , count
SELECT SUM(salary) AS 單月所發放總工資 FROM employees;
SELECT AVG(salary) AS 單月所發的平均工資 FROM employees;
SELECT MAX(salary) AS 單月所發放的最大工資 FROM employees;
SELECT MIN(salary) AS 單月所發放的最小工資 FROM employees;
SELECT COUNT(*) AS 總員工人數 FROM employees;
分組函數的共同特點:會忽略null
分組函數還可以和一個關鍵字合用:DISTINCT
SELECT COUNT(DISTINCT salary) FROM employees;
分組查詢:group by關鍵字實現分組,group by放在where條件語句之后,order by放置在group by的后面
總體的順序先后為:

where條件,group by 分組語句 ,having 分組的條件 ,order by 排序語句
where條件是針對所有記錄的,having 條件只是局限的針對每一組的記錄的

分組查詢語法:

       SELECT
                    列(這個列要求必須只能是group by的后面字段),分組函數()
             FROM
              表名
             WHERE  
                篩選條件
                group by
                    分組字段列表
                having(只能配合group by使用)
              與分組有關的篩選條件(針對分組后的每組內記錄)
                order by
                排序
    #ASC 升序排序
  # DESC 降序排序
案例:查詢每個工種的最高工資
SELECT MAX(salary),job_id FROM employees GROUP BY job_id;
案例:查詢每個地方的部門個數
SELECT location_id,COUNT(*) FROM departments GROUP BY location_id;
案例:查詢每個部門每個工種的員工的平均工資
SELECT  department_id,job_id,AVG(salary) AS 平均工資
           FROM employees GROUP BY department_id,job_id;
案例:查詢員工郵箱里包含a字母的,每個部門的平均工資
SELECT AVG(salary) , department_id FROM employees 
                    WHERE email 
                                        LIKE '%a%'
                                      GROUP BY department_id;   
案例:查詢有獎金的每個領導手下員工的最高工資
SELECT MAX(salary),manager_id FROM employees 
     WHERE commission_pct IS NOT NULL && commission_pct>0
         GROUP BY manager_id;
案例:查詢部門的員工數>5的所有部門的員工數
SELECT COUNT(*) AS 員工個數 ,department_id FROM employees       
                                            GROUP BY department_id
                                     HAVING 員工個數>5;
案例:查詢沒有獎金的每個領導手下員工的最高工資,且最高工資高于7000
 SELECT MAX(salary) AS 最高工資,manager_id FROM employees
                                     WHERE commission_pct is NULL
                    GROUP BY manager_id
                                        HAVING 最高工資 >7000
                                        ORDER BY 最高工資 ASC;

2.連接查詢

連接查詢:又稱多表查詢,當查詢結果來自多張數據表當時候,就需要連接查詢


CREATE TABLE ta(id int,age int);
CREATE TABLE tb(id int,`name` VARCHAR(4),ta_id int);

INSERT INTO  ta(id,age)VALUES(1,12);
INSERT INTO  ta(id,age)VALUES(2,22);
INSERT INTO  ta(id,age)VALUES(3,32);
INSERT INTO  ta(id,age)VALUES(4,42);
INSERT INTO  ta(id,age)VALUES(5,52);
INSERT INTO  ta(id,age)VALUES(6,62);

INSERT INTO tb(id,`name`,ta_id) VALUES(1,'李白',2);
INSERT INTO tb(id,`name`,ta_id)VALUES(2,'小王',1);
INSERT INTO tb(id,`name`,ta_id)VALUES(3,'小張',3);
INSERT INTO tb(id,`name`,ta_id)VALUES(4,'李紅',8);
INSERT INTO tb(id,`name`,ta_id)VALUES(5,'小白',1);
INSERT INTO tb(id,`name`,ta_id)VALUES(6,'王加',10);
INSERT INTO tb(id,`name`,ta_id)VALUES(7,'趙明',10);
INSERT INTO tb(id,`name`,ta_id)VALUES(8,'趙白',6);
#將兩個表組合在一起錯誤 查詢 出現笛卡爾積的結果
SELECT `name`,age FROM ta,tb;

#解決辦法添加上限制條件
#在笛卡爾積的結果上再篩選一次
SELECT `name` , age FROM ta,tb WHERE tb.ta_id=ta.id;

#具體查看連接查詢,先看看連接查詢的分類
# 重要
   按照功能分類:
           內鏈接:
                    等值連接 *
                        非等值連接 *
                        自連接 *
                 外連接:
                     左外連接 *
                     右外連接
                     全外連接
                 交叉連接
 
 等值連接:
 簡單說明就是:表之間用=連接
 分析:SELECT `name` , age FROM ta,tb WHERE tb.ta_id=ta.id;
  它的執行過程,和笛卡爾積一樣,只是在結果集中進行了條件篩選,滿足tb.ta_id=ta.id條件的留下,不滿足的丟棄。
案例:查詢員工和對應的部門名
SELECT last_name,department_name FROM employees,departments
      WHERE employees.department_id =departments.department_id;
用表名來限定字段,太長,不太方方便,在實際運用中,我們一般使用別名來限定定。

SELECT e.last_name,d.department_name FROM employees e,departments d 
WHERE  e.department_id =d.department_id;
注意:等值連接查詢出來的是交集
在等值查詢的基礎上添加查詢條件進行篩選
案例:查詢有獎金定員工名以及所屬部門名:
SELECT last_name,department_name FROM employees e , departments d
       WHERE e.department_id = d.department_id
            AND e.commission_pct IS NOT NULL;
在等值查詢的基礎上加分組查詢
案例:查詢每個城市的部門個數
SELECT COUNT(*) AS 個數,city FROM departments d,locations l
       WHERE d.location_id=l.location_id 
               GROUP BY city;
案例:查詢有獎金的每個部門的部門名和部門的領導編號和該部門的最低工資
SELECT  d.department_name ,d.manager_id,MIN(e.salary) AS 最低工資
FROM departments d ,employees e
WHERE d.department_id = e.department_id AND e.commission_pct IS NOT NULL
GROUP BY d.department_name,d.manager_id;
案例:查詢每個工種的工種名和員工個數,并且按照員工個數排序降序
SELECT j.job_title,COUNT(*) AS 員工個數  FROM jobs j, employees e
          WHERE j.job_id = e.job_id
                    GROUP BY j.job_title
                    ORDER BY 員工個數 DESC;
案例:查詢員工名,部門名和所在城市名
SELECT e.last_name,d.department_name,l.city FROM employees e, departments d,locations l
                WHERE e.department_id = d.department_id AND d.location_id = l.location_id;
注意

本文用到的myemployees.sql 文件在MySQL實戰2 語法、篩選條件和函數 附件中

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,619評論 6 539
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,155評論 3 425
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 177,635評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,539評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,255評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,646評論 1 326
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,655評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,838評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,399評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,146評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,338評論 1 372
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,893評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,565評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,983評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,257評論 1 292
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,059評論 3 397
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,296評論 2 376

推薦閱讀更多精彩內容

  • 引出 ?請思考如下問題? –查詢所有員工的每個月工資總和,平均工資? –查詢工資最高和最低的工資是多少? –查詢公...
    C_cole閱讀 7,310評論 0 3
  • 目標 聚合函數 分組函數 子查詢 多行子查詢 引出 ?請思考如下問題? –查詢所有員工的每個月工資總和,平均工資?...
    wqjcarnation閱讀 4,165評論 0 6
  • SQL語言基礎 本章,我們將會重點探討SQL語言基礎,學習用SQL進行數據庫的基本數據查詢操作。另外請注意本章的S...
    厲鉚兄閱讀 5,341評論 2 46
  • DB:數據庫 能夠完整保存數據,可以盡可能較小冗余,支持多用戶共享的數據集合。 DBMS:數據庫管理系統 創建,管...
    今天不學習閱讀 1,195評論 0 6
  • 1.基本SQL select語句1.1 sqlplus登陸1.2sqlplus 的基本操作1.3基本select語...
    木魚_cc閱讀 887評論 0 1