亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > MySQL多表查詢實例詳解【鏈接查詢、子查詢等】

MySQL多表查詢實例詳解【鏈接查詢、子查詢等】

熱門標簽:在哪里申請400電話 萊西市地圖標注 安徽ai電話電銷機器人有效果嗎 外呼系統電銷受騙 常州網絡外呼系統開發 走過哪個省地圖標注 銷售語音電話機器人 巫師三血與酒地圖標注 400電話申請信用卡

本文實例講述了MySQL多表查詢。分享給大家供大家參考,具體如下:

準備工作:準備兩張表,部門表(department)、員工表(employee)

create table department(
id int,
name varchar(20)
);
create table employee(
id int primary key auto_increment,
name varchar(20),
sex enum('male','female') not null default 'male',
age int,
dep_id int
);

#插入數據
insert into department values
(200,'技術'),
(201,'人力資源'),
(202,'銷售'),
(203,'運營');
insert into employee(name,sex,age,dep_id) values
('egon','male',18,200),
('alex','female',48,201),
('wupeiqi','male',38,201),
('yuanhao','female',28,202),
('nvshen','male',18,200),
('xiaomage','female',18,204)
;

# 查看表結構和數據
mysql> desc department;
+-------+-------------+------+-----+---------+-------+
| Field | Type    | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id  | int(11)   | YES |   | NULL  |    |
| name | varchar(20) | YES |   | NULL  |    |
+-------+-------------+------+-----+---------+-------+
2 rows in set (0.19 sec)

mysql> desc employee;
+--------+-----------------------+------+-----+---------+----------------+
| Field | Type         | Null | Key | Default | Extra     |
+--------+-----------------------+------+-----+---------+----------------+
| id   | int(11)        | NO  | PRI | NULL  | auto_increment |
| name  | varchar(20)      | YES |   | NULL  |        |
| sex  | enum('male','female') | NO  |   | male  |        |
| age  | int(11)        | YES |   | NULL  |        |
| dep_id | int(11)        | YES |   | NULL  |        |
+--------+-----------------------+------+-----+---------+----------------+
5 rows in set (0.01 sec)

mysql> select * from department;
+------+--------------+
| id  | name     |
+------+--------------+
| 200 | 技術     |
| 201 | 人力資源   |
| 202 | 銷售     |
| 203 | 運營     |
+------+--------------+
4 rows in set (0.02 sec)

mysql> select * from employee;
+----+----------+--------+------+--------+
| id | name   | sex  | age | dep_id |
+----+----------+--------+------+--------+
| 1 | egon   | male  |  18 |  200 |
| 2 | alex   | female |  48 |  201 |
| 3 | wupeiqi | male  |  38 |  201 |
| 4 | yuanhao | female |  28 |  202 |
| 5 | nvshen  | male  |  18 |  200 |
| 6 | xiaomage | female |  18 |  204 |
+----+----------+--------+------+--------+
6 rows in set (0.00 sec)

ps:觀察兩張表,發現department表中id=203部門在employee中沒有對應的員工,發現employee中id=6的員工在department表中沒有對應關系。

一多表鏈接查詢

SELECT 字段列表
    FROM 表1 INNER|LEFT|RIGHT JOIN 表2
    ON 表1.字段 = 表2.字段;

(1)先看第一種情況交叉連接:不適用任何匹配條件。生成笛卡爾積.--->重復最多

mysql> select * from employee,department;
+----+----------+--------+------+--------+------+--------------+
| id | name   | sex  | age | dep_id | id  | name     |
+----+----------+--------+------+--------+------+--------------+
| 1 | egon   | male  |  18 |  200 | 200 | 技術     |
| 1 | egon   | male  |  18 |  200 | 201 | 人力資源   |
| 1 | egon   | male  |  18 |  200 | 202 | 銷售     |
| 1 | egon   | male  |  18 |  200 | 203 | 運營     |
| 2 | alex   | female |  48 |  201 | 200 | 技術     |
| 2 | alex   | female |  48 |  201 | 201 | 人力資源   |
| 2 | alex   | female |  48 |  201 | 202 | 銷售     |
| 2 | alex   | female |  48 |  201 | 203 | 運營     |
| 3 | wupeiqi | male  |  38 |  201 | 200 | 技術     |
| 3 | wupeiqi | male  |  38 |  201 | 201 | 人力資源   |
| 3 | wupeiqi | male  |  38 |  201 | 202 | 銷售     |
| 3 | wupeiqi | male  |  38 |  201 | 203 | 運營     |
| 4 | yuanhao | female |  28 |  202 | 200 | 技術     |
| 4 | yuanhao | female |  28 |  202 | 201 | 人力資源   |
| 4 | yuanhao | female |  28 |  202 | 202 | 銷售     |
| 4 | yuanhao | female |  28 |  202 | 203 | 運營     |
| 5 | nvshen  | male  |  18 |  200 | 200 | 技術     |
| 5 | nvshen  | male  |  18 |  200 | 201 | 人力資源   |
| 5 | nvshen  | male  |  18 |  200 | 202 | 銷售     |
| 5 | nvshen  | male  |  18 |  200 | 203 | 運營     |
| 6 | xiaomage | female |  18 |  204 | 200 | 技術     |
| 6 | xiaomage | female |  18 |  204 | 201 | 人力資源   |
| 6 | xiaomage | female |  18 |  204 | 202 | 銷售     |
| 6 | xiaomage | female |  18 |  204 | 203 | 運營     |

(2)內連接:只連接匹配的行,以雙方為基準

#找兩張表共有的部分,相當于利用條件從笛卡爾積結果中篩選出了匹配的結果
#department沒有204這個部門,因而employee表中關于204這條員工信息沒有匹配出來
mysql> select employee.id,employee.name,employee.age,employee.sex,department.name from employee inner join department on employee.dep_id=department.id;
+----+---------+------+--------+--------------+
| id | name  | age | sex  | name     |
+----+---------+------+--------+--------------+
| 1 | egon  |  18 | male  | 技術     |
| 2 | alex  |  48 | female | 人力資源   |
| 3 | wupeiqi |  38 | male  | 人力資源   |
| 4 | yuanhao |  28 | female | 銷售     |
| 5 | nvshen |  18 | male  | 技術     |
+----+---------+------+--------+--------------+
5 rows in set (0.00 sec)

#上述sql等同于
mysql> select employee.id,employee.name,employee.age,employee.sex,department.name from employee,department where employee.dep_id=department.id;

 (3)外鏈接之左連接:優先顯示左表全部記錄

#以左表為準,即找出所有員工信息,當然包括沒有部門的員工
#本質就是:在內連接的基礎上增加左邊有,右邊沒有的結果
mysql> select employee.id,employee.name,department.name as depart_name from employee left join department on employee.dep_id=department.id;
+----+----------+--------------+
| id | name   | depart_name |
+----+----------+--------------+
| 1 | egon   | 技術     |
| 5 | nvshen  | 技術     |
| 2 | alex   | 人力資源   |
| 3 | wupeiqi | 人力資源   |
| 4 | yuanhao | 銷售     |
| 6 | xiaomage | NULL     |
+----+----------+--------------+
6 rows in set (0.00 sec)

(4) 外鏈接之右連接:優先顯示右表全部記錄

#以右表為準,即找出所有部門信息,包括沒有員工的部門
#本質就是:在內連接的基礎上增加右邊有,左邊沒有的結果
mysql> select employee.id,employee.name,department.name as depart_name from employee right join department on employee.dep_id=department.id;
+------+---------+--------------+
| id  | name  | depart_name |
+------+---------+--------------+
|  1 | egon  | 技術     |
|  2 | alex  | 人力資源   |
|  3 | wupeiqi | 人力資源   |
|  4 | yuanhao | 銷售     |
|  5 | nvshen | 技術     |
| NULL | NULL  | 運營     |
+------+---------+--------------+
6 rows in set (0.00 sec)

(5) 全外連接:顯示左右兩個表全部記錄(了解)

#外連接:在內連接的基礎上增加左邊有右邊沒有的和右邊有左邊沒有的結果
#注意:mysql不支持全外連接 full JOIN
#強調:mysql可以使用此種方式間接實現全外連接

語法:select * from employee left join department on employee.dep_id = department.id
       union all
      select * from employee right join department on employee.dep_id = department.id;

 mysql> select * from employee left join department on employee.dep_id = department.id
     union
    select * from employee right join department on employee.dep_id = department.id
      ;
+------+----------+--------+------+--------+------+--------------+
| id  | name   | sex  | age | dep_id | id  | name     |
+------+----------+--------+------+--------+------+--------------+
|  1 | egon   | male  |  18 |  200 | 200 | 技術     |
|  5 | nvshen  | male  |  18 |  200 | 200 | 技術     |
|  2 | alex   | female |  48 |  201 | 201 | 人力資源   |
|  3 | wupeiqi | male  |  38 |  201 | 201 | 人力資源   |
|  4 | yuanhao | female |  28 |  202 | 202 | 銷售     |
|  6 | xiaomage | female |  18 |  204 | NULL | NULL     |
| NULL | NULL   | NULL  | NULL |  NULL | 203 | 運營     |
+------+----------+--------+------+--------+------+--------------+
7 rows in set (0.01 sec)

#注意 union與union all的區別:union會去掉相同的紀錄

二、符合條件連接查詢

以內連接的方式查詢employee和department表,并且employee表中的age字段值必須大于25,即找出年齡大于25歲的員工以及員工所在的部門

select employee.name,department.name from employee inner join department
  on employee.dep_id = department.id
  where age > 25;

三、子查詢

#1:子查詢是將一個查詢語句嵌套在另一個查詢語句中。
#2:內層查詢語句的查詢結果,可以為外層查詢語句提供查詢條件。
#3:子查詢中可以包含:IN、NOT IN、ANY、ALL、EXISTS 和 NOT EXISTS等關鍵字
#4:還可以包含比較運算符:= 、 !=、> 、等

(1)帶in關鍵字的子查詢

#查詢平均年齡在25歲以上的部門名
select id,name from department
  where id in
    (select dep_id from employee group by dep_id having avg(age) > 25);
# 查看技術部員工姓名
select name from employee
  where dep_id in
    (select id from department where name='技術');
#查看不足1人的部門名
select name from department
  where id not in
    (select dep_id from employee group by dep_id);

(2)帶比較運算符的子查詢

#比較運算符:=、!=、>、>=、、=、>
#查詢大于所有人平均年齡的員工名與年齡
mysql> select name,age from employee where age > (select avg(age) from employee);
+---------+------+
| name  | age |
+---------+------+
| alex  |  48 |
| wupeiqi |  38 |
+---------+------+
#查詢大于部門內平均年齡的員工名、年齡

思路:

(1)先對員工表(employee)中的人員分組(group by),查詢出dep_id以及平均年齡。
(2)將查出的結果作為臨時表,再對根據臨時表的dep_id和employee的dep_id作為篩選條件將employee表和臨時表進行內連接。
(3)最后再將employee員工的年齡是大于平均年齡的員工名字和年齡篩選。

mysql> select t1.name,t1.age from employee as t1
       inner join
      (select dep_id,avg(age) as avg_age from employee group by dep_id) as t2
      on t1.dep_id = t2.dep_id
      where t1.age > t2.avg_age;
+------+------+
| name | age |
+------+------+
| alex |  48 |

 (3)帶EXISTS關鍵字的子查詢

#EXISTS關字鍵字表示存在。在使用EXISTS關鍵字時,內層查詢語句不返回查詢的記錄。而是返回一個真假值。True或False
#當返回True時,外層查詢語句將進行查詢;當返回值為False時,外層查詢語句不進行查詢
#department表中存在dept_id=203,Ture
mysql> select * from employee where exists (select id from department where id=200);
+----+----------+--------+------+--------+
| id | name   | sex  | age | dep_id |
+----+----------+--------+------+--------+
| 1 | egon   | male  |  18 |  200 |
| 2 | alex   | female |  48 |  201 |
| 3 | wupeiqi | male  |  38 |  201 |
| 4 | yuanhao | female |  28 |  202 |
| 5 | nvshen  | male  |  18 |  200 |
| 6 | xiaomage | female |  18 |  204 |
+----+----------+--------+------+--------+
#department表中存在dept_id=205,False
mysql> select * from employee where exists (select id from department where id=204);
Empty set (0.00 sec)

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL查詢技巧大全》、《MySQL常用函數大匯總》、《MySQL日志操作技巧大全》、《MySQL事務操作技巧匯總》、《MySQL存儲過程技巧大全》及《MySQL數據庫鎖相關技巧匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

您可能感興趣的文章:
  • IDEA鏈接MySQL報錯08001和連接成功后不顯示表的問題及解決方法
  • mysql安裝navicat之后,出現2059,Authentication plugin及本地鏈接虛擬機docker,遠程鏈接服務器
  • python pymysql鏈接數據庫查詢結果轉為Dataframe實例
  • 實例操作MySQL短鏈接
  • MySql 8.0.11 安裝過程及 Navicat 鏈接時遇到的問題小結
  • 詳解MySQL分組鏈接的使用技巧
  • MySql使用skip-name-resolve解決外網鏈接客戶端過慢問題
  • 利用ssh tunnel鏈接mysql服務器的方法
  • MySQL 查看鏈接及殺掉異常鏈接的方法

標簽:河北 鞍山 來賓 黃石 果洛 煙臺 陽江 赤峰

巨人網絡通訊聲明:本文標題《MySQL多表查詢實例詳解【鏈接查詢、子查詢等】》,本文關鍵詞  MySQL,多表,查詢,實例,詳解,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL多表查詢實例詳解【鏈接查詢、子查詢等】》相關的同類信息!
  • 本頁收集關于MySQL多表查詢實例詳解【鏈接查詢、子查詢等】的相關信息資訊供網民參考!
  • 推薦文章
    日本乱中文字幕系列| 成人影院一区二区三区| 精品视频一区二区三区免费| 久久福利影视| 99久久精品国产麻豆| 久久国产精品自线拍免费| 四虎影视久久久| 欧美激情一区二区三区中文字幕| 久久国产一区二区| 九九久久99| 91麻豆国产| 91麻豆精品国产自产在线 | 亚州视频一区二区| 亚洲 男人 天堂| 亚州视频一区二区| 久久福利影视| 欧美另类videosbestsex| 成人a大片在线观看| 欧美一级视频免费观看| 日日爽天天| 久久99这里只有精品国产| 成人免费观看男女羞羞视频| 可以免费看毛片的网站| 欧美日本免费| 麻豆午夜视频| 日韩一级黄色| 精品久久久久久影院免费| 成人免费福利片在线观看| 欧美激情一区二区三区视频高清| 日韩一级黄色| 91麻豆精品国产高清在线| 日本特黄特色aaa大片免费| 一本伊大人香蕉高清在线观看| 国产韩国精品一区二区三区| 国产一区免费观看| 久草免费在线视频| 久久99青青久久99久久| 精品国产香蕉在线播出| 亚洲女人国产香蕉久久精品| 亚洲女初尝黑人巨高清在线观看| 日本在线www| 日韩男人天堂| 午夜精品国产自在现线拍| 高清一级片| 日韩一级黄色大片| 99色吧| 91麻豆国产福利精品| 国产伦久视频免费观看 视频| 国产一区二区精品久久91| 欧美激情一区二区三区在线播放| 久久国产精品自线拍免费| 成人高清视频在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 精品美女| 色综合久久天天综线观看| 亚洲第一页乱| 久草免费在线观看| 亚洲www美色| 四虎影视久久久| 欧美一区二区三区在线观看| 久久久成人网| 色综合久久手机在线| 韩国三级香港三级日本三级la| 欧美日本韩国| 欧美大片aaaa一级毛片| 精品国产一区二区三区久久久狼 | 99色视频在线| 国产网站免费在线观看| 日日日夜夜操| 成人免费观看网欧美片| 午夜在线亚洲男人午在线| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品视频在线观看免费| 中文字幕一区二区三区 精品| 天天色色网| 99色视频在线| 91麻豆精品国产自产在线| 成人免费高清视频| 国产视频一区二区在线播放| 国产成a人片在线观看视频| 久久精品免视看国产成人2021| 国产国语在线播放视频| 国产高清在线精品一区二区| 99热热久久| 亚洲精品影院久久久久久| 久久精品大片| 欧美激情中文字幕一区二区| 可以免费看毛片的网站| 国产不卡高清在线观看视频| 成人影院久久久久久影院| 国产一区二区高清视频| 国产成人精品综合在线| 国产麻豆精品免费视频| 国产福利免费视频| 四虎影视久久久| 99热视热频这里只有精品| 麻豆网站在线看| 欧美18性精品| 人人干人人草| 国产一区二区精品| 久久国产精品永久免费网站| 日韩专区亚洲综合久久| 天天色成人网| 九九热精品免费观看| 日日爽天天| 精品国产亚洲人成在线| 美国一区二区三区| 日本特黄特色aa大片免费| 国产网站免费视频| 日韩欧美一二三区| 色综合久久天天综线观看| 韩国毛片免费| 台湾美女古装一级毛片| 久久久久久久网| 天天做人人爱夜夜爽2020| 欧美电影免费| 国产综合91天堂亚洲国产| 久久福利影视| 国产国语对白一级毛片| 精品国产亚一区二区三区| 日日爽天天| 亚洲精品影院一区二区| 午夜在线观看视频免费 成人| 韩国三级香港三级日本三级| 欧美国产日韩在线| 日韩一级黄色| 日韩在线观看免费| 久久国产一区二区| 欧美日本韩国| 日韩综合| 精品国产一区二区三区久久久蜜臀| 日韩免费在线| 久久国产一久久高清| 亚州视频一区二区| 欧美国产日韩精品| 国产一区二区精品久久91| 国产成人精品综合| 国产高清在线精品一区a| 麻豆午夜视频| 国产极品白嫩美女在线观看看| 国产精品免费久久| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品视频在线看 | 欧美激情伊人| 四虎久久影院| 欧美日本免费| 久草免费在线视频| 国产高清在线精品一区a| 成人a大片在线观看| 亚洲精品影院一区二区| 99色吧| 欧美一级视频免费| 成人免费福利片在线观看| 成人免费一级毛片在线播放视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情一区二区三区视频高清| 久久久久久久免费视频| 成人高清视频在线观看| 欧美a级片免费看| 欧美国产日韩在线| 一本伊大人香蕉高清在线观看| 精品视频一区二区| 欧美a免费| 二级特黄绝大片免费视频大片| 亚洲 国产精品 日韩| 美女免费精品高清毛片在线视| 欧美大片aaaa一级毛片| 成人影视在线播放| 美国一区二区三区| 韩国毛片免费| 亚欧成人毛片一区二区三区四区| 日韩av东京社区男人的天堂| 国产一区二区精品在线观看| 亚洲 国产精品 日韩| 精品国产亚一区二区三区| 国产麻豆精品hdvideoss| 麻豆网站在线看| 一级女性全黄久久生活片| 日日日夜夜操| 日韩专区亚洲综合久久| 精品国产香蕉在线播出 | 韩国毛片免费大片| 免费国产在线观看不卡| 国产成人精品影视| 久久99这里只有精品国产| 日本在线不卡视频| 久久国产精品自线拍免费| 免费国产在线观看| 黄色免费三级| 免费国产在线观看| 999精品影视在线观看| 亚洲精品中文一区不卡 | 91麻豆精品国产综合久久久| 日本伦理黄色大片在线观看网站| 国产成人女人在线视频观看| 欧美爱色| 麻豆网站在线免费观看| 日日日夜夜操| 国产美女在线一区二区三区| 日日日夜夜操|