完全掌握mysql多表操作
本篇文章為大家帶來了關於mysql的相關知識,其中主要介紹了多表操作的相關問題,包括了多表關係、外鍵約束、多表聯合查詢、內連接查詢和外連接查詢等等,希望對大家有幫助。
推薦學習:mysql教學
#多表關係
一對一(一般是合併表) ,
一對多/多對一(部門和員工),
多對多(學生和課程)——用中間表
外鍵約束概念
#專門用於多表關係的約束
透過主表的主鍵來控制從表的外鍵
外鍵約束:
1、主表必須已經存在,或者正在建立
2、必須要為主表設定主鍵列
3、主鍵不能包含空值,但是外鍵可以包含空值
4、在主表的表名後面指定的列明或者列名的組合。這個列或列的組合必須是主表的主鍵或候選鍵
5、外鍵中列的數目必須和主鍵中列的數目相同
6、外鍵中列的資料型別必須與主鍵中對應列的資料類型相同
• 建立外鍵約束foreign key
在建立表之前新增外鍵約束
要先給主表添加約束
從表格新增約束要依賴主表,主表沒有的資料不能加上
主表的資料被從表依賴時,不能刪除,否則可以刪除
從表的資料可以任意刪除
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;
A表的一行對應B表的多行,B表的一行對應A表的多行,這時候需要再重新建立一個
中間表,記錄表關係
#修改和刪除時,中間從表可以隨便刪除和修改,但是兩邊從表手主表依賴的資料不能刪除或修改。
就是同時
查詢兩個或兩個以上的表,因為有時用戶在查看資料的時候,需要顯示的資料來自多張表
注意:
外鍵約束只對資料的增刪改起作用,對於資料查詢沒有影響
select * from A ,B;--會產生冗餘資料
兩個表所有資料行的笛卡爾積 2、笛卡爾集可以理解為一張表的每一行去和另外一張表的任意一行進行匹配
3、假如A表有m 行數據,B表有n 行數據,則返回
m * n 行數據 4、笛卡爾積會產生很多
冗餘的數據,後期的其他查詢可以在該集合的基礎上進行條件篩選
交集
inner 可以省略
select * from A,B where 条件;
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;
左外連接
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
来达到目的
----外连接查询
----查询哪些部门有员工,哪些部门没有员工
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;
----外连接查询
----查询哪些部门有员工,哪些部门没有员工
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;
----查询哪些员工有对应的部门,哪些没有
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;
----实现满外连接: 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
• 基本子查询
• 子查询关键字-ALL
• 子查询关键字-ANY ,SOME
• 子查询关键字-IN
• 子查询关键字-EXISTS
• 自关联查询
推荐学习:mysql视频教程
以上是完全掌握mysql多表操作的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

Apache 連接數據庫需要以下步驟:安裝數據庫驅動程序。配置 web.xml 文件以創建連接池。創建 JDBC 數據源,指定連接設置。從 Java 代碼中使用 JDBC API 訪問數據庫,包括獲取連接、創建語句、綁定參數、執行查詢或更新以及處理結果。

MySQL是一種開源的關係型數據庫管理系統,主要用於快速、可靠地存儲和檢索數據。其工作原理包括客戶端請求、查詢解析、執行查詢和返回結果。使用示例包括創建表、插入和查詢數據,以及高級功能如JOIN操作。常見錯誤涉及SQL語法、數據類型和權限問題,優化建議包括使用索引、優化查詢和分錶分區。

MySQL在數據庫和編程中的地位非常重要,它是一個開源的關係型數據庫管理系統,廣泛應用於各種應用場景。 1)MySQL提供高效的數據存儲、組織和檢索功能,支持Web、移動和企業級系統。 2)它使用客戶端-服務器架構,支持多種存儲引擎和索引優化。 3)基本用法包括創建表和插入數據,高級用法涉及多表JOIN和復雜查詢。 4)常見問題如SQL語法錯誤和性能問題可以通過EXPLAIN命令和慢查詢日誌調試。 5)性能優化方法包括合理使用索引、優化查詢和使用緩存,最佳實踐包括使用事務和PreparedStatemen

選擇MySQL的原因是其性能、可靠性、易用性和社區支持。 1.MySQL提供高效的數據存儲和檢索功能,支持多種數據類型和高級查詢操作。 2.採用客戶端-服務器架構和多種存儲引擎,支持事務和查詢優化。 3.易於使用,支持多種操作系統和編程語言。 4.擁有強大的社區支持,提供豐富的資源和解決方案。

MySQL在Web應用中的主要作用是存儲和管理數據。 1.MySQL高效處理用戶信息、產品目錄和交易記錄等數據。 2.通過SQL查詢,開發者能從數據庫提取信息生成動態內容。 3.MySQL基於客戶端-服務器模型工作,確保查詢速度可接受。

在 Docker 中啟動 MySQL 的過程包含以下步驟:拉取 MySQL 鏡像創建並啟動容器,設置根用戶密碼並映射端口驗證連接創建數據庫和用戶授予對數據庫的所有權限

Laravel 是一款 PHP 框架,用於輕鬆構建 Web 應用程序。它提供一系列強大的功能,包括:安裝: 使用 Composer 全局安裝 Laravel CLI,並在項目目錄中創建應用程序。路由: 在 routes/web.php 中定義 URL 和處理函數之間的關係。視圖: 在 resources/views 中創建視圖以呈現應用程序的界面。數據庫集成: 提供與 MySQL 等數據庫的開箱即用集成,並使用遷移來創建和修改表。模型和控制器: 模型表示數據庫實體,控制器處理 HTTP 請求。

在開發一個小型應用時,我遇到了一個棘手的問題:需要快速集成一個輕量級的數據庫操作庫。嘗試了多個庫後,我發現它們要么功能過多,要么兼容性不佳。最終,我找到了minii/db,這是一個基於Yii2的簡化版本,完美地解決了我的問題。
