连接查询
1.无连接规则
select语句中不设任何连接条件,结果是表1中的每一行都会和表2中的每一行进行连接,得到一个笛卡儿积。
2、有连接规则
在无连接规则的基础上,加上WHERE子句
使用INNER JOIN进行多表连接
SELECT *(或字段列表)
FROM 表1
INNER JOIN 表2
ON 连接规则1
INNER JOIN 表3
ON 连接规则2
…
3、高级连接查询
自连接:当需要两次查询才能完成并且查询内容同属一张表时,可以将表分别取不同别名
内连接:有连接规则的连接都属于内连接,有等值连接、自然连接、不等值连接
左外连接:LEFT OUTER JOIN 表(把表左侧的表的所有记录包含在结果集)
右外连接:RIGHT OUTER JOIN(右边表的所有记录包含在结果集)
全外连接:FULL OUTER JOIN(两表的所有记录都包含在结果集)
交叉连接:无规则连接,可以用逗号隔开表名(常用),可以用CROSS JOIN连接表名,返回一个笛卡儿积。
组合查询
SELECT *
UNION(ALL–不删除重复值)
SELECT *
UNION
…
将每一个查询语句的结果集竖着合并组成新的结果集
注
1、每个SELECT内的字段个数一定要相同,可以补null
2、且对应字段的类型兼容(相同),不同时强制转换
子查询
在SELECT语句中嵌套的SELECT语句,几乎被内连接取代
通常配合聚合函数使用,因为WHERE子句中不能包含聚合函数