pace_03 2022-05-03 00:42 采纳率: 69.2%
浏览 209
已结题

hive编写sql命令查询统计百分比

有两个表如下:要求统计 2021 年内 Lenovo 品牌销量占总销量的百分比

  • orders表
    order_idorder_dateitem_idbuyer_idseller_id
    12021-4-1412
    22022-4-2213
    32021-4-3323
    42022-4-4141
    52022-4-5134
    62021-4-6224

说明:order_id 订单号、order_date 订单日期、item_id 商品 ID、buyer_id 买家 ID、seller_id卖家 ID

  • items表
    item_iditem_brand
    1Samsung
    2Lenovo
    3LG
    4HP

说明: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,我也知道不对:(

  • 写回答

2条回答 默认 最新

  • 夜猫nightcat 2022-05-03 01:52
    关注

    首先两张表关联起来,然后计算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);
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 5月10日
  • 已采纳回答 5月3日
  • 修改了问题 5月3日
  • 创建了问题 5月3日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵