jpa+mysql,union组合查询求和结果出错

6 篇文章 0 订阅

UNION ALL

有两个表,A和B。

A表数据类似

ida1a2a3a4a5
150.5ag1...
2101.0ag2...
3151.5ag1...

B表数据类似

ida1a2a3a4a5
1102bg2...
2204bg1...
3306bg1...


SELECT count(*), sum(x),sum(y),z,w FROM ( 
(SELECT a1 as x, a2 as y, a3 as z, a4 as w FROM A)
UNION ALL 
(SELECT b1 as x, b3 as z, b2 as y, b4 as w FROM B)
)t  GROUP BY w
结果发现,sum(x)结果是对的,但sum(y)是错的,为什么呢?

因为按照我的思路,UNION的select结果应该是:

xyzw
50.5ag1
101.0ag2
151.5ag1
102bg2
204bg1
306bg1

但实际上结果却是:

xyzw
50.5ag1
101.0ag2
151.5ag1
10b2g2
20b4g1
30b6g1

注意:y下面的三行不是数字,而是字母。

这时来看上面被union的两个select的字段顺序,

第一个是:a1,a2,a3,a4,

第二个是:b1,b3,b2,b4,

虽然其对应的xyzw都没对应错,但是:

union查询时并不会按你为各字段起的别名进行一一对应,而是按你的select时的字段顺序进行对应的

 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值