目錄
#多表關係
外鍵約束概念
外鍵約束:
首頁 資料庫 mysql教程 完全掌握mysql多表操作

完全掌握mysql多表操作

Mar 28, 2022 pm 01:48 PM
mysql

本篇文章為大家帶來了關於mysql的相關知識,其中主要介紹了多表操作的相關問題,包括了多表關係、外鍵約束、多表聯合查詢、內連接查詢和外連接查詢等等,希望對大家有幫助。

完全掌握mysql多表操作

推薦學習:mysql教學

#多表關係

一對一(一般是合併表) ,
一對多/多對一(部門和員工),
多對多(學生和課程)——用中間表

外鍵約束概念

#專門用於多表關係的約束
透過主表的主鍵來控制從表的外鍵

外鍵約束:

1、主表必須已經存在,或者正在建立
2、必須要為主表設定主鍵列
3、主鍵不能包含空值,但是外鍵可以包含空值
4、在主表的表名後面指定的列明或者列名的組合。這個列或列的組合必須是主表的主鍵或候選鍵
5、外鍵中列的數目必須和主鍵中列的數目相同
6、外鍵中列的資料型別必須與主鍵中對應列的資料類型相同

• 建立外鍵約束foreign key
在建立表之前新增外鍵約束
完全掌握mysql多表操作

# #在建立表之後加入外鍵約束

完全掌握mysql多表操作

驗證外鍵約束的作用

1、資料插入:

要先給主表添加約束
從表格新增約束要依賴主表,主表沒有的資料不能加上

完全掌握mysql多表操作

2、資料刪除

主表的資料被從表依賴時,不能刪除,否則可以刪除
從表的資料可以任意刪除

eg:

delete from dept where deptno = '1001';-----不可以删除(被依赖了)delete from dept where deptno = '1004';
------可以删除delete from emp where eid = '7';  -----可以删除
登入後複製
刪除外鍵約束

刪除之後,表與表之間就沒有關係了

語法:

alter table 表名字 drop foreign key 外键约束名alter table emp2 drop foreign key emp2_fk;
登入後複製

完全掌握mysql多表操作

• 多對多關係-建構外鍵約束

A表的一行對應B表的多行,B表的一行對應A表的多行,這時候需要再重新建立一個
中間表,記錄表關係
完全掌握mysql多表操作

注意:


#修改和刪除時,中間從表可以隨便刪除和修改,但是兩邊從表手主表依賴的資料不能刪除或修改。

多表聯合查詢(非常重要)

• 概念

就是同時
查詢兩個或兩個以上的表,因為有時用戶在查看資料的時候,需要顯示的資料來自多張表

• 資料準備

注意:
外鍵約束只對資料的增刪改起作用,對於資料查詢沒有影響

• 交叉連接查詢

select * from A ,B;--會產生冗餘資料

1、交叉連接查詢傳回被連接的

兩個表所有資料行的笛卡爾積 2、笛卡爾集可以理解為一張表的每一行去和另外一張表的任意一行進行匹配
3、假如A表有m 行數據,B表有n 行數據,則返回
m * n 行數據 4、笛卡爾積會產生很多
冗餘的數據,後期的其他查詢可以在該集合的基礎上進行條件篩選

內連接查詢

求的是兩個表之間的

交集
完全掌握mysql多表操作

inner 可以省略

隱含內連線(SQL92標準):

select * from A,B where 条件;
登入後複製
明確內連線(SQL99標準);

select * from A inner join B on 条件
登入後複製
---查询每个部门的所属员工  //隐式内连接
登入後複製
select* from dept3,emp3 where dept3.deptno = emp3.dept_id;  //这样写标准
登入後複製
也可以給予表起別名,如;

select* from dept3  a ,emp3 b  where a.deptno = b.dept_id;
登入後複製
	---查询每个部门的所属员工  
	//显式内连接select *from dept3 inner join emp3  on dept3.deptno = emp3.dept_id;  
	//这样写标准
登入後複製
也可以給表起別名,如;

select *from dept3 a join emp3 b on a.deptno = b.dept_id;
登入後複製

完全掌握mysql多表操作

完全掌握mysql多表操作
完全掌握mysql多表操作

外連接查詢

分為:(outer可以省略)

左外連接
left outer join

select* from A left outer join B on 条件;
登入後複製
右外連接

right outer join

select* from A right outer join B on 条件;
登入後複製
滿外連線

full outer join

select* from A full outer join B on 条件;
登入後複製

注意:
Oracle 里面有 full join ,可是在mysql 对 full join 支持的不好,我们可以使用 union来达到目的
完全掌握mysql多表操作

----外连接查询
----查询哪些部门有员工,哪些部门没有员工

use mydb3;select* from dept3 left outer join emp3 on dept3.deptno =emp3.dept_id;
登入後複製

----查询哪些员工有对应的部门,哪些没有

select* from dept3 right outer join emp3 on dept3.deptno =emp3.dept_id;
登入後複製

----使用 union 关键字实现左外连接和右外连接的并集

select* from dept3 left outer join emp3 on dept3.deptno=emp3.dept_idunionselect* from dept3 right outer join emp3 on dept3.deptno =emp3.dept_id;
登入後複製

完全掌握mysql多表操作

----外连接查询
----查询哪些部门有员工,哪些部门没有员工

usemydb3;select* from dept3 a left outer join emp3 b on a.deptno = b.dept.idselect* from dept3 a left join emp3 b on a.deptno = b.dept_id;
登入後複製

----外连接多个表

select* from Aleft join B on 条件1left join C on 条件2left join D on 条件3;
登入後複製

完全掌握mysql多表操作

----查询哪些员工有对应的部门,哪些没有

select * from dept3 a right outer join emp3 b on a.deptno = b.dept_id;select* from dept3 a right join emp3 b on a.deptno = b,dept_id;select*from Aright joinB on条件1,right joinC on条件2,right joinD on条件3;
登入後複製

完全掌握mysql多表操作

----实现满外连接: full join
----使用 union 关键字实现左外连接和右外连接的并集
----select * from dept3 a full join emp3 b on a.deptno = b.dept_id; --不能执行

----union是将两个查询结果上下拼接,并去重

select* from dept3 a left join emp3 b on a.deptno = b.dept_idunionselect* from dept3 a right join emp3 b on a.deptno = b.dept_id
登入後複製

----union all 是将两个查询结果上下拼接,不去重

select* from dept3 a left join emp3 b on a.deptno = b.dept_idunion allselect* from dept3 a right join emp3 b on a.deptno= b.dept_id
登入後複製

完全掌握mysql多表操作

• 基本子查询
• 子查询关键字-ALL
• 子查询关键字-ANY ,SOME
• 子查询关键字-IN
• 子查询关键字-EXISTS
• 自关联查询

推荐学习:mysql视频教程

以上是完全掌握mysql多表操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前 By 尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

PHP 的大數據結構處理技巧 PHP 的大數據結構處理技巧 May 08, 2024 am 10:24 AM

PHP 的大數據結構處理技巧

如何優化 PHP 中的 MySQL 查詢效能? 如何優化 PHP 中的 MySQL 查詢效能? Jun 03, 2024 pm 08:11 PM

如何優化 PHP 中的 MySQL 查詢效能?

如何在 PHP 中使用 MySQL 備份和還原? 如何在 PHP 中使用 MySQL 備份和還原? Jun 03, 2024 pm 12:19 PM

如何在 PHP 中使用 MySQL 備份和還原?

如何使用 PHP 插入資料到 MySQL 表? 如何使用 PHP 插入資料到 MySQL 表? Jun 02, 2024 pm 02:26 PM

如何使用 PHP 插入資料到 MySQL 表?

Java 枚舉類型在資料庫中的應用場景有哪些? Java 枚舉類型在資料庫中的應用場景有哪些? May 05, 2024 am 09:06 AM

Java 枚舉類型在資料庫中的應用場景有哪些?

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤 Dec 09, 2024 am 11:42 AM

如何修復 MySQL 8.4 上的 mysql_native_password 未載入錯誤

如何在 PHP 中使用 MySQL 預存程序? 如何在 PHP 中使用 MySQL 預存程序? Jun 02, 2024 pm 02:13 PM

如何在 PHP 中使用 MySQL 預存程序?

如何使用 PHP 建立 MySQL 表? 如何使用 PHP 建立 MySQL 表? Jun 04, 2024 pm 01:57 PM

如何使用 PHP 建立 MySQL 表?

See all articles