MySQL基礎之Natural Join用法


Natural join即自然連接,natural join等同於inner join或inner using,其作用是將兩個表中具有相同名稱的列進行匹配

用https://www.w3resource.com的圖例:
在這里插入圖片描述

Natural join特征:

  • 關聯的表具有一對或多對同名的列
  • 連接時候不需要使用on或者using關鍵字

建立兩張表:

CREATE TABLE t1(id INT,desc1 VARCHAR(50),desc2 VARCHAR(50))ENGINE=INNODB;
CREATE TABLE t2(id INT,desc3 VARCHAR(50),desc4 VARCHAR(50))ENGINE=INNODB;

往兩張表寫數據:

INSERT INTO t1(id,desc1,desc2) VALUES(100,'desc11','desc12'),(101,'desc21','desc22'),(102,'desc31','desc32');
INSERT INTO t2(id,desc3,desc4) VALUES(101,'desc41','desc42'),(103,'desc51','desc52'),(105,'desc61','desc62');

內連接查詢id相同的數據

SELECT t1.id,t2.id,desc1,desc2,desc3,desc4 FROM t1 INNER JOIN t2 ON t1.id = t2.id;

natural join連接查詢的效果等同於如上sql

SELECT t1.id,t2.id,desc1,desc2,desc3,desc4 FROM t1 NATURAL JOIN t2;

在這里插入圖片描述
ok,接着驗證列類型不一樣是否還可以繼續關聯,本博客只在mysql5.7版本驗證
在這里插入圖片描述
修改一下t1的id類型

ALTER TABLE t1 MODIFY id VARCHAR(50);

繼續查詢,用natural join,驗證后發現還可以查詢的

SELECT t1.id,t2.id,desc1,desc2,desc3,desc4 FROM t1 NATURAL JOIN t2;

用內連接的方法,ps:Oracle里id類型不一樣(一個為int,一個為varchar)是會報錯的,不過我在5.7版本驗證,並沒有報錯

SELECT t1.id,t2.id,desc1,desc2,desc3,desc4 FROM t1 INNER JOIN t2 ON t1.id = t2.id;

所以,我懷疑是否因為sql_mode沒有開啟為嚴格模式導致的?

SET @session.sql_mode = 'STRICT_TRANS_TABLES';

開啟嚴格模式,繼續查詢都沒問題,所以mysql的語法還是相對沒那么嚴格限制的

ok,綜上,可以得出,natural join只是根據列的名稱和數據進行關聯而已,在5.7版本並沒有限制要求列的類型要一樣,而且natural join連接時候也不需要使用on或者using關鍵字


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM