关于一个疑惑问题,请高手帮忙

zhangzs8896 2003-09-23 03:43:04
SELECT OIPRLT.BECYNO, SUM(ips262a.订单量) AS 热处理负载
into #hot
FROM ips262a INNER JOIN
OIPRLT ON ips262a.AJCONK =OIPRLT.BECONK
WHERE (OIPRLT.BESTAT = 20)AND (ips262a.AJPRLV = 31)
GROUP BY OIPRLT.BECYNO

select * from #hot
where becyno='30932'

drop table #hot
----------------------------
SELECT OIPRLT.BECYNO, ips262a.订单量 AS 热处理负载
into #hot
FROM ips262a INNER JOIN
OIPRLT ON ips262a.AJCONK =OIPRLT.BECONK
WHERE (OIPRLT.BESTAT = 20)AND (ips262a.AJPRLV = 31)
GROUP BY OIPRLT.BECYNO,ips262a.订单量


select sum(热处理负载) as 热处理负载 from #hot
where becyno='30932'

drop table #hot

为什么得到的最后结果不一样呢?
...全文
93 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
Wally_wu 2003-09-23
  • 打赏
  • 举报
回复
就因为这个分组函数,
aierong 2003-09-23
  • 打赏
  • 举报
回复


可以把你表的结构和数据拿来看看吗

不明白
伍子V5 2003-09-23
  • 打赏
  • 举报
回复
比如这一组数据

1001,1000
1001,1000
1001,100

1002,2000
1003,3000

第一种得
1001,2100
1002,2000
1003,3000

第二种得
1001,1000
1001,100
1002,2000
1003,3000

在SUM后结果肯定不一样了
伍子V5 2003-09-23
  • 打赏
  • 举报
回复
你的第二中方法中如果有一条记录BECYNO和订单量
都相同的话,将只选一条

所以第一种是正确的

34,874

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧