Title

每日一句

mysql内连接查询之自连接

连接查询:
当查询数据时,通过连接操作查询出存放在多个表中的不同数据,当两个或者多个表中存在相同意义的字段时,
便可以通过这些字段对不同的表进行连接查询。
自连接:
如果在一个连接查询中,涉及的两个表都是同一个表,这种查询称为自连接查询。自连接是一种特殊的内连接,
它是指相互连接的表在物理上为同一张表,但可以在逻辑上分为两张表。
例:下面是一张公司员工表,要求找出每个员工的上级,并显示员工名和上级名。

如图,name表示员工名,id表示员工编号,mac表示上级编号

此时,员工表和上级表在同一个表中,应该用到自连接,仔细观察可以发现字段id和字段mac有关联,
因此逻辑上可以把一张表看作两张表
emp a 员工表

emp b 上级表

sql语句

查询结果

可以发现员工名和上级名反了。
错误在哪呢?其实最后的等值条件错了,
两张表的关系为员工的上级编号=上级的员工编号
所以修改sql为

查询结果

查询正确
总结:关于自连接应该理解它是把一张表看作两张表关键在于找两张表的关系,只要能找到关系,就能够写出sql语句。

posted @ 2021-02-05 19:09  江公  阅读(860)  评论(0编辑  收藏  举报
Title

每日一句