MySQL實戰(zhàn)3 分組查詢和連接查詢

MySQL實戰(zhàn) 目錄

1.分組查詢

分組函數(shù)和前面講的函數(shù)不同在于胖齐,前面的對內(nèi)容本身的處理,而分組函數(shù)的主要功能是統(tǒng)計。

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

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

分組查詢語法:

       SELECT
                    列(這個列要求必須只能是group by的后面字段),分組函數(shù)()
             FROM
              表名
             WHERE  
                篩選條件
                group by
                    分組字段列表
                having(只能配合group by使用)
              與分組有關(guān)的篩選條件(針對分組后的每組內(nèi)記錄)
                order by
                排序
    #ASC 升序排序
  # DESC 降序排序
案例:查詢每個工種的最高工資
SELECT MAX(salary),job_id FROM employees GROUP BY job_id;
案例:查詢每個地方的部門個數(shù)
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;
案例:查詢部門的員工數(shù)>5的所有部門的員工數(shù)
SELECT COUNT(*) AS 員工個數(shù) ,department_id FROM employees       
                                            GROUP BY department_id
                                     HAVING 員工個數(shù)>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.連接查詢

連接查詢:又稱多表查詢参咙,當查詢結(jié)果來自多張數(shù)據(jù)表當時候,就需要連接查詢


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);
#將兩個表組合在一起錯誤 查詢 出現(xiàn)笛卡爾積的結(jié)果
SELECT `name`,age FROM ta,tb;

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

#具體查看連接查詢硫眯,先看看連接查詢的分類
# 重要
   按照功能分類:
           內(nèi)鏈接:
                    等值連接 *
                        非等值連接 *
                        自連接 *
                 外連接:
                     左外連接 *
                     右外連接
                     全外連接
                 交叉連接
 
 等值連接:
 簡單說明就是:表之間用=連接
 分析:SELECT `name` , age FROM ta,tb WHERE tb.ta_id=ta.id;
  它的執(zhí)行過程蕴侧,和笛卡爾積一樣,只是在結(jié)果集中進行了條件篩選两入,滿足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;
在等值查詢的基礎上加分組查詢
案例:查詢每個城市的部門個數(shù)
SELECT COUNT(*) AS 個數(shù),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;
案例:查詢每個工種的工種名和員工個數(shù),并且按照員工個數(shù)排序降序
SELECT j.job_title,COUNT(*) AS 員工個數(shù)  FROM jobs j, employees e
          WHERE j.job_id = e.job_id
                    GROUP BY j.job_title
                    ORDER BY 員工個數(shù) 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實戰(zhàn)2 語法已添、篩選條件和函數(shù) 附件中

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末妥箕,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子更舞,更是在濱河造成了極大的恐慌畦幢,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缆蝉,死亡現(xiàn)場離奇詭異宇葱,居然都是意外死亡,警方通過查閱死者的電腦和手機刊头,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進店門黍瞧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人芽偏,你說我怎么就攤上這事∠曳恚” “怎么了污尉?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長往产。 經(jīng)常有香客問我被碗,道長,這世上最難降的妖魔是什么仿村? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任锐朴,我火速辦了婚禮,結(jié)果婚禮上蔼囊,老公的妹妹穿的比我還像新娘焚志。我一直安慰自己,他們只是感情好畏鼓,可當我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布酱酬。 她就那樣靜靜地躺著,像睡著了一般云矫。 火紅的嫁衣襯著肌膚如雪膳沽。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天让禀,我揣著相機與錄音挑社,去河邊找鬼。 笑死巡揍,一個胖子當著我的面吹牛痛阻,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播腮敌,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼录平,長吁一口氣:“原來是場噩夢啊……” “哼麻车!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起斗这,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤动猬,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后表箭,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體赁咙,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年免钻,在試婚紗的時候發(fā)現(xiàn)自己被綠了彼水。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡极舔,死狀恐怖凤覆,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情拆魏,我是刑警寧澤盯桦,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站渤刃,受9級特大地震影響拥峦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜卖子,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一略号、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧洋闽,春花似錦玄柠、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至骚勘,卻和暖如春铐伴,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背俏讹。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工当宴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人泽疆。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓户矢,卻偏偏與公主長得像,于是被迫代替她去往敵國和親殉疼。 傳聞我的和親對象是個殘疾皇子梯浪,可洞房花燭夜當晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 引出 ?請思考如下問題捌年? –查詢所有員工的每個月工資總和,平均工資挂洛? –查詢工資最高和最低的工資是多少礼预? –查詢公...
    C_cole閱讀 7,289評論 0 3
  • 目標 聚合函數(shù) 分組函數(shù) 子查詢 多行子查詢 引出 ?請思考如下問題? –查詢所有員工的每個月工資總和虏劲,平均工資托酸?...
    wqjcarnation閱讀 4,150評論 0 6
  • SQL語言基礎 本章,我們將會重點探討SQL語言基礎柒巫,學習用SQL進行數(shù)據(jù)庫的基本數(shù)據(jù)查詢操作励堡。另外請注意本章的S...
    厲鉚兄閱讀 5,320評論 2 46
  • DB:數(shù)據(jù)庫 能夠完整保存數(shù)據(jù),可以盡可能較小冗余堡掏,支持多用戶共享的數(shù)據(jù)集合应结。 DBMS:數(shù)據(jù)庫管理系統(tǒng) 創(chuàng)建,管...
    今天不學習閱讀 1,185評論 0 6
  • 1.基本SQL select語句1.1 sqlplus登陸1.2sqlplus 的基本操作1.3基本select語...
    木魚_cc閱讀 882評論 0 1