MySQL刷题:进店却未进行交易的顾客

1.题目描述

有一些顾客可能光顾了购物中心但没有进行交易。请你编写一个解决方案,来查找这些顾客的 ID ,以及他们只光顾不交易的次数。返回以 任何顺序 排序的结果表。返回结果格式如下例所示:
在这里插入图片描述
在这里插入图片描述
要求返回的图为:
在这里插入图片描述

2.解答

其中很明显的是采用外连结

select *
from visits as v
left outer join transactions as tr
on v.visit_id=tr.visit_id;

在这里插入图片描述
首先说明的是两张表连结后,其实是所有的列都在的,所以后续进行引用的时候采用的都是 表名.列名的格式,即使这个列两个表都有。
观察需要输出的结果可以发现对于不是 null 的值就是发生消费的记录,而我们需要的是没有消费的 vist,那些值为 null 的表示该visit 记录并没有发生交易,所以要把这些交易过滤出来

select *
from visits as v
left outer join transactions as tr
on v.visit_id=tr.visit_id
where transaction_id is null;

在这里插入图片描述
那接下来就是 select 的步骤了

select v.customer_id ,count(v.visit_id) as count_no_trans 
from visits as v
left outer join transactions as tr
on v.visit_id=tr.visit_id
where transaction_id is null
group by customer_id;

其中select 中 count()中的v.visit_id 中的表名不要丢了,否则就会指代不明报错。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

素梦秋影

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值