Mysql關(guān)聯(lián)查詢的幾種實現(xiàn)方式
在關(guān)系型數(shù)據(jù)庫中,要進行多表查詢,一般都會使用join連接。
join連接的本質(zhì)其實類似與集合的交并操作,Mysql實現(xiàn)關(guān)聯(lián)查詢常見的幾種方式如下;
本次測試表結(jié)構(gòu)和數(shù)據(jù):
- A表

- B表

1、左連接
概念說明:
左連接將左表A作為主表,右表B作為從表,左表作為外層循環(huán),在右表中進行匹配,如果左表的記錄在右表中沒有匹配,則將該左表記錄的右表項補空值;

語法&測試:
語法關(guān)鍵字為 LEFT JOIN,影響行數(shù) 4 行;

2、右連接
概念說明:
右連接將右表B作為主表,左表A作為從表,右表作為外層循環(huán),在左表中進行匹配,如果右表的記錄在左表中沒有匹配,則將該右表記錄的左表項補空值;

語法&測試:
語法關(guān)鍵字為 RIGHT JOIN,影響行數(shù) 4 行;

3、內(nèi)連接
概念說明:
內(nèi)連接將左表A和右表B對于條件相匹配的項進行組合,在結(jié)果中只會出現(xiàn)同時在左表和右表出現(xiàn)的項;

語法&測試:
語法關(guān)鍵字為 INNER JOIN 或 JOIN(JOIN等價于INNER JOIN),影響行數(shù) 3 行;

4、全連接
概念說明:
全外連接將左表A和右表B的所有記錄進行匹配,如果在另外表項中不存在記錄,則補空值;

語法&測試:
語法關(guān)鍵字為 UNION 用來組合左連接和右連接,影響行數(shù) 5 行;

5、左外連接
概念說明:
左外連接選擇將左表A作為主表,右表B作為從表,循環(huán)遍歷右表,查找與條件滿足的項,如果在右表中沒有匹配的項,則補空值,并且在結(jié)果集中選擇只在左表中存在的數(shù)據(jù);

語法&測試:
左表A獨有的數(shù)據(jù),影響行數(shù) 1 行;

6、右外連接
概念說明:
右外連接選擇將右表作為主表,左表作為從表,循環(huán)遍歷左表,查找與join條件滿足的項,如果在左表中沒有匹配的項,則補空值,并且在結(jié)果集中選擇只在右表中存在的數(shù)據(jù);

語法&測試:
右表B獨有的數(shù)據(jù),影響行數(shù) 1 行;

7、全外連接
概念說明:
全外連接將全連接中左右表相交的部分排除;

語法&測試:
左表A和右表B獨有的數(shù)據(jù),影響行數(shù) 2 行;

總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
在Windows主機上定時備份遠程VPS(CentOS)數(shù)據(jù)的批處理
我想在自己的 Windows7 下每天/周運行一次備份,就有了這個小工具2012-05-05
Navicat Premiun遠程連接MySQL報錯10038解決方案
這篇文章主要介紹了Navicat Premiun遠程連接MySQL報錯10038解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11
Mysql 刪除數(shù)據(jù)庫drop database詳細介紹
在mysql中,我們可以使用DROP DATABASE來刪除數(shù)據(jù)庫,并且數(shù)據(jù)庫中所有表也隨之刪除。本文通過實例向各位碼農(nóng)介紹DROP DATABASE的使用方法,需要的朋友可以參考下2016-11-11
Mysql經(jīng)典高逼格/命令行操作(速成)(推薦)
這篇文章主要介紹了Mysql命令行操作,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-04-04
MySQL數(shù)據(jù)庫復合查詢與內(nèi)外連接圖文詳解
本文詳細介紹了在SQL中進行多表查詢的技術(shù),包括笛卡爾積、自連接、子查詢、內(nèi)連接和外連接等,文章還解釋了union和unionall的區(qū)別,以及如何在from子句中使用子查詢,這些技術(shù)對于處理復雜的數(shù)據(jù)庫查詢非常重要,可以有效地從不同表中提取和組合數(shù)據(jù),需要的朋友可以參考下2024-10-10
mysql獲取group by的總記錄行數(shù)另類方法
mysql獲取group by內(nèi)部可以獲取到某字段的記錄分組統(tǒng)計總數(shù),而無法統(tǒng)計出分組的記錄數(shù),下面有個可行的方法,大家可以看看2014-10-10

