多表连接查询和

连接查询
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子句中不能包含聚合函数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值