MySQL中的连接有内连接,外连接,以及交叉连接(笛卡尔积)
1. cross join(交叉连接):指如果不带WHERE条件子句,将会返回被连接的两个表的笛卡尔积,返回结果的行数等于两个表行数的乘积2.inner join(内连接):通常有2中情况:
a、等值连接(=号应用于连接条件,不会去除重复的列)例如:select * from table1 as a inner join table2 as b on a.column=b.column
b、不等连接(>,>=,<=,!=,<>)
例如:select * from table1 as a inner join table2 as b on a.column<>b.column
3.outer join(外连接)
a、左外连接LEFT [OUTER] JOIN--显示符合条件的数据行,同时显示左边数据表不符合条件的数据行,右边没有对应的条目显示NULL
例如:select * from table1 as a left [outer] join table2 as b on a.column=b.column
b、右连接RIGHT [OUTER] JOIN--显示符合条件的数据行,同时显示右边数据表不符合条件的数据行,左边没有对应的条目显示null
例如:select * from table1 as a right [outer] join table2 as b on a.column=b.column
c、全外连接--显示符合条件的数据行,同时显示左右不符合条件的数据行,无对应的左右两边显示null
join与union不一样,union这个运算只是将资料列合并,而join是将栏位合并。
union 对两个结果集进行并集操作,不包括重复行,同时进行默认规则的排序;
union all 对两个结果集进行并集操作, 包括重复行, 不进行排序;
intersect 对两个结果集进行交集操作,不包括重复行,同时进行默认规则的排序;
minus 对两个结果集进行差操作, 不包括重复行,同时进行默认规则的排序。
例如:select Column1,Column2 from table 1 union select Column1,Column2 from table 2