mysql中的自关联详解_解析mysql的自连接和join关联

这篇文章主要给大家介绍了关于mysql的自连接和join关联的相关资料,文中介绍的非常详细,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。

一、mysql自连接

mysql有时在信息查询时需要进行对自身连接(自连接),所以我们需要为表定义别名。我们举例说明,下面是商品采购表,我们需要找到采购价格比惠惠高的所有信息。

f88e5765b1024058046700d0d12b9b59-0.png

一般情况我们看到这张表我们第一时间用语句进行操作:SELECT * FROM shoping WHERE price>27

可想而知,这是有多么简单,假设你并不知道数据库表详细数据或者数据量相当庞大呢?作为一个数据库管理员,我们就要用别的方式迅速找出所需要的数据。

分步查询

最简单的一种方式,也是最容易想到操作:SELECT price FROM shopping WHERE name='惠惠' //得出price查询结果为27

SELECT * FROM shopping WHERE price>27

与采用自连接的方式相比,这种方法需要对中间结果进行人工干预,显然不利于程序中的自动处理操作。

自连接方式:SELECT b.*

from shopping as a,shopping as b

where a.name='惠惠'

and a.price

order by b.id

我们可以获取到如下表信息:

cf70128cd6eaf9e9d19c50549be3cc6f-1.png

注意点:

别名 a,b虽然名称不同,但是同一个表,定义别名的目的是更方便在自身进行删选。

执行select通过(中间表)所得到的b.*,,就是最终结果。

子查询

子查询也是常用的一种方式,就是在select里嵌套select。

实现代码如下:SELECT * FROM shopping

WHERE price>(select price from 'shopping' where name='惠惠')

所得结果如下所示,可见两种方式所得结果相同:

5cd406a7f12bebd7aa8a8bc095631642-2.png

二、JOIN

INNER JOIN

内关联的主要作用是在表中存在至少一个匹配时,就返回结果集,这里的inner join和join作用相同,所以一起介绍。

下面给出两张表,分别为goods和category表:

5cd406a7f12bebd7aa8a8bc095631642-3.png

dd2eba2b919d30f76517cd42c9f12de7-4.png

SELECT * FROM goods INNER JOIN category

ON goods.id=category.goods_id

ORDER BY gods.id

结果如下所示:

dd2eba2b919d30f76517cd42c9f12de7-5.png

LEFT JOIN

LEFT JOIN 关键字会从左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中没有匹配的行。做项目时建议使用左关联。但是存在很多表关联的,一个表对a是左连接,但同时对b是右连接,这时加上右连接,写起来可能方便一些。

套用一开始的两张表,进行左关联查询:SELECT goods.*,category.cate_name

FROM goods LEFT JOIN category

ON goods.id=category.goods_id

ORDER BY goods.id

dd2eba2b919d30f76517cd42c9f12de7-6.png

RIGHT JOIN

RIGHT JOIN 关键字会右表 (table_name2) 那里返回所有的行,即使在左表 (table_name1) 中没有匹配的行。套用一开始的两张表进行右关联查询:SELECT a.goods_name,a.price,b.*

FROM goods as a

RIGHT JOIN category as b

ON a.id=b.goods_id

ORDER BY b.id

b4ffcf4434e155ff3d2691551955bf8d-7.png

对于多表关联的情况,就是多加几条关联语句。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值