欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL中的交叉連接、自然連接和內(nèi)連接查詢詳解

 更新時間:2025年04月11日 11:47:22   作者:今天自洽了嗎  
這篇文章主要介紹了MySQL中的交叉連接、自然連接和內(nèi)連接查詢,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

一、引入

實際開發(fā)中往往需要針對兩張甚至更多張數(shù)據(jù)表進行操作,而這多張表之間需要使用主鍵和外鍵關(guān)聯(lián)在一起,然后使用連接查詢來查詢多張表中滿足要求的數(shù)據(jù)記錄

一條SQL語句查詢多個表,得到一個結(jié)果,包含多個表的數(shù)據(jù)。效率高。

多種連接查詢的類型:

  • cross
  • natural
  • using
  • on

二、交叉連接(cross join)

交叉連接(CROSS JOIN)是對兩個或者多個表進行笛卡兒積操作,所謂笛卡兒積就是關(guān)系代數(shù)里的一個概念,表示兩個表中的每一行數(shù)據(jù)任意組合的結(jié)果。

比如:有兩個表,左表有m條數(shù)據(jù)記錄,x個字段,右表有n條數(shù)據(jù)記錄,y個字段,則執(zhí)行交叉連接后將返回m*n條數(shù)據(jù)記錄,x+y個字段。笛卡兒積示意圖如圖所示。

我希望查找員工編號、員工姓名、部門編號和部門名稱這4個字段的數(shù)據(jù),在員工表emp中可以查詢到員工編號、員工姓名、部門編號的數(shù)據(jù),在部門表dept中可以查詢到字段部門名稱的數(shù)據(jù),如果想同時查找這些數(shù)據(jù),需要使用多表查詢語法,交叉連接cross join:

查詢員工表emp:

select * from emp;

查詢部門表dept:

select * from dept;

一條SQL查詢兩個表:

select * from emp cross join dept;

表emp14條記錄,表dept4條記錄,交叉連接查詢后,14*4=56條記錄,交叉連接就是對這兩個表進行笛卡爾乘積操作,笛卡爾乘積沒有實際意義,但是有理論意義。

關(guān)于交叉連接的寫法,MySQL中可以省略cross,Oracle中不可以省略不寫,上條SQL等價于:

select * from emp join dept;

三、自然連接(natural join)

交叉連接會查詢到許多冗余數(shù)據(jù),比如在員工表emp和部門表dept中,讓主鍵和外鍵關(guān)聯(lián)起來的外鍵deptno,沒有匹配到一起,造成數(shù)據(jù)冗余:

使用自然連接,可以自動匹配所有的同名列,讓同名列只在查詢中展示一次,提高查詢效率,

select * from emp natural join dept;

可以指定查詢的部分字段:

select empno,ename,deptno,dname from emp natural join dept;

當查詢一個字段時,系統(tǒng)會分別從兩個關(guān)聯(lián)的表中查找,因此效率較低,為解決這個問題,我們可以在查詢目標字段時,指定表名,格式為表名.字段名

select emp.empno,emp.ename,emp.deptno,dept.dname from emp natural join dept;

查詢結(jié)果和上述一致,但是查詢效率得到了提升。

此時,如果表名過長,查詢的SQL也會過長,在查詢時,我們可以為表起別名:

select e.empno,e.ename,d.dname,d.deptno
from emp e
natural join dept d;

四、內(nèi)連接

使用natural join 的缺點:會自動匹配表中所有的同名列,但是有的時候我們希望只匹配部分同名列,那么我們可以使用using子句,這屬于內(nèi)連接(inner join)

select * 
from emp as e
inner join dept as d
using(deptno);

using子句的缺點:關(guān)聯(lián)的字段,必須是同名的

解決方法:使用內(nèi)連接中的on子句

select * 
from emp e
inner join dept d
on (e.deptno = d.deptno);

五、總結(jié)

多表查詢的類型有:

  1. 交叉連接 cross join
  2. 自然連接 natural join
  3. 內(nèi)連接 - using子句
  4. 內(nèi)連接 - on子句

綜合來看:內(nèi)連接 - on子句的使用頻率最高。

六、補充

select *
from emp e
inner join dept d
on (e.deptno = d.deptno)
where sal > 3500;

條件:

1、篩選條件 where having

2、連接條件 on/using/natural

在SQL99語法當中,篩選條件和連接條件是分開的。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • MySQL重命名表名的實現(xiàn)示例

    MySQL重命名表名的實現(xiàn)示例

    在MySQL中,可以通過RENAMETABLE和ALTERTABLE命令來重命名表,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-10-10
  • 在MySQL中同時查找兩張表中的數(shù)據(jù)的示例

    在MySQL中同時查找兩張表中的數(shù)據(jù)的示例

    這篇文章主要介紹了在MySQL中同時查找兩張表中的數(shù)據(jù)的示例,即一次查詢操作返回兩張表的結(jié)果,需要的朋友可以參考下
    2015-07-07
  • MySQL分區(qū)表分區(qū)策略詳解

    MySQL分區(qū)表分區(qū)策略詳解

    這篇文章主要介紹了MySQL分區(qū)表分區(qū)策略詳解,分區(qū)是一種表的設(shè)計模式,通俗地講表分區(qū)是將一大表,根據(jù)條件分割成若干個小表。但是對于應(yīng)用程序來講,分區(qū)的表和沒有分區(qū)的表是一樣的,需要的朋友可以參考下
    2023-07-07
  • MySQL開啟遠程訪問權(quán)限的最新方法

    MySQL開啟遠程訪問權(quán)限的最新方法

    這篇文章主要給大家介紹了關(guān)于MySQL開啟遠程訪問權(quán)限的最新方法,在MySQL中,要實現(xiàn)遠程訪問,首先需要在MySQL服務(wù)端上開啟相應(yīng)的權(quán)限,需要的朋友可以參考下
    2023-08-08
  • 減少mysql主從數(shù)據(jù)同步延遲問題的詳解

    減少mysql主從數(shù)據(jù)同步延遲問題的詳解

    本篇文章是對減少mysql主從數(shù)據(jù)同步延遲的問題進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • mysql免安裝版1067錯誤終極解決辦法圖文教程

    mysql免安裝版1067錯誤終極解決辦法圖文教程

    這篇文章主要介紹了mysql免安裝版1067錯誤終極解決辦法圖文教程,從筆記本到pc端。本文給大家介紹的非常詳細,需要的朋友參考下
    2017-01-01
  • MySQL遷移到PostgreSQL操作指南

    MySQL遷移到PostgreSQL操作指南

    這篇文章主要介紹了MySQL遷移到PostgreSQL操作指南,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起來學(xué)習(xí)吧
    2023-10-10
  • 解決Mysql多行子查詢的使用及空值問題

    解決Mysql多行子查詢的使用及空值問題

    所謂多行子查詢,是指執(zhí)行查詢語句獲得的結(jié)果集中返回了多行數(shù)據(jù)的子查詢,今天通過本文給大家分享Mysql多行子查詢的使用及空值問題,感興趣的朋友一起看看吧
    2022-01-01
  • MySQL 百萬級分頁優(yōu)化(Mysql千萬級快速分頁)

    MySQL 百萬級分頁優(yōu)化(Mysql千萬級快速分頁)

    MySql 性能到底能有多高?用了php半年多,真正如此深入的去思考這個問題還是從前天開始。有過痛苦有過絕望,到現(xiàn)在充滿信心
    2012-11-11
  • linux下mysql自動備份數(shù)據(jù)庫與自動刪除臨時文件

    linux下mysql自動備份數(shù)據(jù)庫與自動刪除臨時文件

    mysql自動備份數(shù)據(jù)庫與自動刪除臨時文件,有需要的朋友可以參考下
    2013-02-02

最新評論