等值连接、内连接、左连接(左外连接)、右连接(右外连接)、全连接、笛卡尔积
UserInfo表:
WorkInfo表:
1、等值连接:从左表中取出每一条记录,去右表中与所有的记录进行匹配:匹配必须是某个条件在左表中与右表中相同最终才会保留结果,否则不保留。
2、内连接
以上可以看出,内连接有两种写法,一种是inner join,另一种是join,这两种写法都是一样的,可以理解为join是inner join的缩写。还可以看出,等值连接和内连接的效果一样,但是开发中建议使用内连接,因为等值连接在查询的时候会将2个表会先进行笛卡尔乘积运算,生成一个新表格,占据在电脑内存里,当表的数据量很大时,很耗内存,这种方法效率比较低;内连接查询时会将2个表根据共同ID进行逐条匹配,不会出现笛卡尔乘积的现象,效率比较高。
3、左连接,也成为左外连接:从左表那里返回所有的行,即使在右表中没有匹配的行。
4、右连接,也成为右外连接:右表那里返回所有的行,即使在左表 中没有匹配的行。
5、全连接:只要其中某个表存在匹配,FULL JOIN 关键字就会返回行。
6、笛卡尔乘积:通俗的说就是查询所得的结果行数是两张表行数的乘积。