有两个表如下:要求统计 2021 年内 Lenovo 品牌销量占总销量的百分比
order_id | order_date | item_id | buyer_id | seller_id |
---|---|---|---|---|
1 | 2021-4-1 | 4 | 1 | 2 |
2 | 2022-4-2 | 2 | 1 | 3 |
3 | 2021-4-3 | 3 | 2 | 3 |
4 | 2022-4-4 | 1 | 4 | 1 |
5 | 2022-4-5 | 1 | 3 | 4 |
6 | 2021-4-6 | 2 | 2 | 4 |
说明:order_id 订单号、order_date 订单日期、item_id 商品 ID、buyer_id 买家 ID、seller_id卖家 ID
item_id | item_brand |
---|---|
1 | Samsung |
2 | Lenovo |
3 | LG |
4 | HP |
说明:item_id 商品 ID、item_brand 商品品牌
现在要查询统计 2021 年内 Lenovo 品牌销量占总销量的百分比,sql语句怎么写呢?
以下是我的能力写出来的
select count(orders.item_id) / count(order_id) from orders,items
where orders.item_id = items.item_id and item_brand = 'Lenovo';
运行结果为1.0,我也知道不对:(
首先两张表关联起来,然后计算Lenovo订单数量,再除以总数量就可以了
select
(select count(1) from orders o join items i
on o.item_id = i.item_id
where i.item_brand = Lenovo)/
(select count(order_id) from orders);
关于为什么楼主你写的sql最后答案是1,原因在于你后面的where子句。
item.brand=联想。筛选出来的是是只有联想的。
再加上orders.item_id =item.item_id,找到id互相对应的。
可是楼主你想过没有,你写的sql语句,找到的都是联想的数据。select的时候就是联想数量/联想数量