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關鍵字
