MYSQL 左连接右连接和内连接的详解及区别
MYSQL左连接右连接和内连接的区别,这里就对这些概念经过一个实例,讲解清楚。
代码如下:
droptabletable1; CREATETABLE`andrew`.`table1` ( `name`VARCHAR(32)NOTNULL, `city`VARCHAR(32)NOTNULL ) ENGINE=MyISAM; insertintoTABLE1(name,city)values('PersonA','BJ'); insertintoTABLE1(name,city)values('PersonB','BJ'); insertintoTABLE1(name,city)values('PersonC','SH'); insertintoTABLE1(name,city)values('PersonD','SZ'); commit; droptabletable2; CREATETABLE`andrew`.`table2` ( `name`VARCHAR(32)NOTNULL, `city`VARCHAR(32)NOTNULL ) ENGINE=MyISAM; insertintoTABLE2(name,city)values('PersonW','BJ'); insertintoTABLE2(name,city)values('PersonX','SH'); insertintoTABLE2(name,city)values('PersonY','SH'); insertintoTABLE2(name,city)values('PersonZ','NJ'); commit;
1.外连接–左连接结果
table1居左,故谓之左连接。这种情况下,以table1为主,即table1中的所有记录均会被列出。有一下三种情况:
a.对于table1中的每一条记录对应的城市如果在table2中也恰好存在而且刚好只有一条,那么就会在
返回的结果中形成一条新的记录。如上面PersonA和PersonB对应的情况。
b.对于table1中的每一条记录对应的城市如果在table2中也恰好存在而且有N条,那么就会在返回的结果中形成N条新的记录。如上面的PersonC对应的情况。
c.对于table1中的每一条记录对应的城市如果在table2中不存在,那么就会在返回的结果中形成一条
条新的记录,且该记录的右边全部NULL。如上面的PersonD对应的情况。
不符合上面三条规则的记录不会被列出。
2.外连接–右连接结果
table2居右,故谓之右连接。这种情况下,以table2为主,即table2中的所有记录均会被列出。有一下三种情况:
a.对于table2中的每一条记录对应的城市如果在table1中也恰好存在而且刚好只有一条,那么就会在
返回的结果中形成一条新的记录。如上面PersonX和PersonY对应的情况。
b.对于table2中的每一条记录对应的城市如果在table1中也恰好存在而且有N条,那么就会在返回的结果中形成N条新的记录。如上面的PersonW对应的情况。
c.对于table2中的每一条记录对应的城市如果在table1中不存在,那么就会在返回的结果中形成一条
条新的记录,且该记录的左边全部NULL。如上面的PersonZ对应的情况。
不符合上面三条规则的记录不会被列出。
3.内连接
内连接的数据记录中,不会存在字段为NULL的情况。可以简单地认为,内链接的结果就是在左连接或者右连接的结果中剔除存在字段为NULL的记录后所得到的结果。甚至可以认为,如果两个表中仅分别剩下内连接运算后所得的数据记录,如table1中只有PersonA、PersonB和PersonC,table2中只有PersonW、PersonX和PersonY,那么这两个表的之间的左连接和右连接的返回的结果是一样的。
注意:select*fromtable1ainnerjointable2bona.city=b.city和select*fromtable1ajointable2bona.city=b.city的效果是一样的,即如果join的左边没有诸如left、right或者inner这样的关键字时,缺省的是内连接。另,MySQL不支持fulljoin。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!