https://www.cnblogs.com/poloyy/category/1683347.html
前言
- 利用条件表达式来消除交叉连接(cross join)的多余数据行
- inner join通过 on 来设置条件表达式,如果没有加on的话,inner join和cross join是相同的
- cross join ... on 和 inner on 其实效果也是一样的(但在标准sql中,cross join是不支持on的,只是MysqL支持)
inner join 的语法格式
SELECT <字段名> FROM <表1INNER JOIN <表2> [ON子句]
- inner join 可以连接 ≥ 两个的表
- inner join 也可以使用 where 来指定连接条件,但是 on 是官方标准写法,而且 where 可能会影响查询性能
- inner join 也可以只写 join 不加 inner
先看看dept、emp表有什么数据
dept表
emp表
inner join 的栗子
标准内连接:查询每个员工的部门详细信息
两张表相连
select * from emp as a join dept as b on a.dept_id = b.id; as a = b.id;
注意点
可以看到emp表id=7、9的数据是没有返回的,dept表id=4的数据也是没有返回的,这就是inner join的特性:只有两张表相互匹配到的数据才会返回(满足查询条件的数据),简单理解就是:取交集
特殊内连接,自连接:查询有leader的员工以及leader信息
自连接:同一张表相连
join emp on a.leader = b.id;
特殊内连接,不等值连接
不等值连接:查询条件的逻辑运算符是大于或小于
> b.id;
知识点
- 在多表查询的时候,字段名都需要通过表名指定 表名.字段名
- 如果表名太长可以用给表起别名,这样就变成 别名.字段名 ,如上面的 a 、 b 就是别名, a.dept_id 、 b.id
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。