MySQL的多表聯查和嵌套查詢


1.數據准備

### 創建表與插入數據准備

```python
#建表
create table dep2(
id int,
name varchar(20) 
);

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

#插入數據
insert into dep2 values
(200,'技術'),
(201,'人力資源'),
(202,'銷售'),
(203,'運營');

insert into emp2(name,sex,age,dep_id) values
('tank','male',17,200),
('egon','female',48,201),
('kevin','male',38,201),
('jason','female',28,202),
('owen','male',18,200),
('sean','female',18,204);

# PS: 昨天講了如何根據表關系對字段進行拆分,目的是為了更好的管理,表數據都存放在硬盤中,存不是目的,目的是為了取,所以我們將數據從硬盤讀到內存中,接下來我們因應該將他們拼成一張表來查詢更加合理;

# 注意: 將拆分的表,再拼接到一起進行查詢, 可以通過一張表查另一張表的數據;
```



### 1、關聯查詢

```mysql
# 左表的一條記錄與右表的一條記錄都對應一遍稱之為 --> "笛卡爾積"   PS: 百度科普
# 將所有的數據都對應了一遍,雖然不合理但是其中有合理的數據,現在我們需要做的就是找出合理的數據
View Code

2. 聯表查詢和子查詢

1、inner join
# 1、內連接:只取兩張表有對應關系的記錄
select * from emp2 inner join dep2 on emp2.dep_id = dep2.id;
select * from emp2 inner join dep2 on emp2.dep_id = dep2.id and dep2.name = '技術';

2、left join
# 2、左連接: 在內連接的基礎上保留左表沒有對應關系的記錄
select * from emp2 left join dep2 on emp2.dep_id = dep2.id;

3、right join
# 3、右連接: 在內連接的基礎上保留右表沒有對應關系的記錄
select * from emp2 right join dep2 on emp2.dep_id = dep2.id;

4、union
# 4、全連接:在內連接的基礎上保留左、右面表沒有對應關系的的記錄
select * from emp2 left join dep2 on emp2.dep_id = dep2.id
union
select * from emp2 right join dep2 on emp2.dep_id = dep2.id;
```
### 2、子查詢

```mysql
# 子查詢就是將一個查詢語句的結果用括號括起來,當做另一個查詢語句的條件去用

# 1.查詢部門是技術或者人力資源的員工信息
'''
先獲取技術部和人力資源的id號,再去員工表里根據前面的id篩選出符合要求的員工信息;
'''
select * from emp2 where dep_id in (select id from dep2 where name='技術' or name='人力資源');


# 2.每個部門最新入職的員工 思路:先查每個部門最新入職的員工,再按部門對應上聯表查詢
# 查第一張emp表
select t1.id, t1.name, t1.hire_date, t1.post, t2.* from emp as t1 
inner join 
(select post, max(hire_date) as max_date from emp group by post) as t2 
on t1.post = t2.post
where t1.hire_date = t2.max_date;

3.三表聯查的一些示例

SELECT
S.SName AS 姓名, CS.CourseName AS 課程, C.Score AS 成績 FROM Students AS S # 注意:並不是from student下面所有的連表都直接和studnet 相連,比如四張表,五張表 INNER JOIN Score AS C ON S.SCode
= C.StudentID # stdent表先和score表 形成一個大表 INNER JOIN Course AS CS ON CS.CourseID = C.CourseID # 再用這張大表和課程表相連

4. 查詢較為復雜時,一次寫不出sql  可以分步來寫

查詢掛科超過兩門(包括兩門)的學生姓名和班級

select student.sname,class.cid,t.student_id from student 
inner join 
(select student_id,count(*) as count from score where num <60 group by student_id HAVING count > 1) as t on t.count = student.sid inner join class on student.class_id = class.cid

 


免責聲明!

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



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