帮我看下SQL语句错在哪里

学习 时间:2026-04-06 22:24:24 阅读:4526
帮我看下SQL语句错在哪里select a.comid as 货号,a.barcode as 条码,sum(b.stock_qty) as 总库存,sum(c.sale_qnty) as 总销售fromtemp01 a left join bwsyv9_01.dbo.ic_t_branch_stock b on(a.item_no = b.item_no ) left join bwsyv9_01.dbo.pos_t_saleflow c on(a.item_no = c.item_no)wherea.yesno ='0'group bya.comid,a.barcodeselect a.comid as 货号,a.barcode as 条码,sum(b.stock_qty) as 总库存数,sum(c.sale_qnty) as 总销售fromtemp01 a,bwsyv9_01.dbo.pos_t_saleflow c,bwsyv9_01.dbo.ic_t_branch_stock bwhere(a.item_no = c.item_no and a.item_no = b.item_no) and a.yesno ='0'group bya.comid,a.barcode这两个语句都有同样一个错误 SUM()函数内统计的数量完全不正确我用商品资料表同时结联了一个库存与一个销售表 之后查出来就不正确了(SUM统计的库存与销售都是多倍的)如果我只用一个JOIN(结联一个表)就不会出现这种问题帮我看下错在哪里?

最佳回答

义气的泥猴桃

踏实的太阳

2026-04-06 22:24:24

以你第一个为例,主要是你在销售和库存中有多条同一个item_no的记录,所以造成笛卡尔积 第一个这样select a。comid as 货号,a。barcode as 条码,b。总库存,c。总销售 from temp01 left join(select item_no,sum(stock_qty) as 总库存 from bwsyv9_01。dbo。ic_t_branch_stock group by item_no) bon a。item_no = b。item_no left join (select item_no,sum(sale_qnty) as 总销售 from  bwsyv9_01。dbo。pos_t_saleflow group by item_no) con a。item_no = c。item_no where a。yesno ='0'你第二个应该也是类似问题

最新回答共有2条回答

  • 专注的魔镜
    回复
    2026-04-06 22:24:24

    以你第一个为例,主要是你在销售和库存中有多条同一个item_no的记录,所以造成笛卡尔积 第一个这样select a。comid as 货号,a。barcode as 条码,b。总库存,c。总销售 from temp01 left join(select item_no,sum(stock_qty) as 总库存 from bwsyv9_01。dbo。ic_t_branch_stock group by item_no) bon a。item_no = b。item_no left join (select item_no,sum(sale_qnty) as 总销售 from  bwsyv9_01。dbo。pos_t_saleflow group by item_no) con a。item_no = c。item_no where a。yesno ='0'你第二个应该也是类似问题

上一篇 下面是防灾减灾日的标志,请仔细观察画面内容,并阐述其所表达的含义

下一篇 某种氢氧化钠溶液中含氧元素80%,该溶液中含氢氧化钠的质量分数为