[TOC]
# 多表數據操作
## EXCEL數據案例分析

## 表之間的關系
* 一對多(多對一)
在多的一方加入一的一方的外鍵。
* 多對多
通過一個中間表將兩個表之間建立關系。
* 一對一
在所謂的子表中加入所謂主表的外鍵,并加上唯一性約束。
## 表關聯查詢
**案例表結構**

> 作業:按照表結構,新建表,并插入假數據
**自然連接查詢**
> 使用 WHERE 條件將兩個表之間進行關聯查詢
```sql
-- 查詢學員的學號、姓名、所在班級名稱
SELECT s.clazz_id,s.code,s.name,c.id,c.name
FROM student as s, clazz as c
WHERE S.clazz_id = C.id
```
要注意的是,如果不加條件,直接查詢,會把兩個表進行笛卡爾積的操作,查詢出來的數據是有問題。
**內連接查詢**
> 內連接查詢是可以使用自然連接查詢替代的,但是效率方面,內連接會高
```sql
-- 內連接查詢
SELECT s.code, s.name, c.name FROM student s
INNER JOIN clazz c ON s.clazz_id = c.id
```
**左外連接查詢**
> 以左表為主表,左表中的數據都會被顯示出來,關聯的右表中,如果存在符合條件的數據,那么會被關聯出并顯示,如果沒有,則會顯示 NULL。
```sql
-- 左外連接
SELECT s.code, s.name, c.name FROM student s
LEFT JOIN clazz c ON s.clazz_id = c.id
```
**綜合查詢**
```sql
-- 查詢學員選課信息,要求顯示出班級、賬號、課程等基礎信息
SELECT
cl.name as '班級名稱',
s.code as '學號',
s.name as '姓名',
a.username as '賬號',
a.password as '賬號密碼',
c.name as '課程名稱'
FROM student_course sc
LEFT JOIN student s ON sc.student_id = s.id
LEFT JOIN course c on sc.course_id = c.id
LEFT JOIN clazz cl on s.clazz_id = cl.id
LEFT JOIN account a on a.student_id = s.id
```
自學內容:右外連接