mysql 查询结果求和

mysql 查询结果求和,第1张

1、创建三张测试表,

create table pw_memberinfo(uid int, name varchar(20))

create table pw_members(companyid int, uid int)

create table pw_memberdata(uid int, deposit int, ddeposit int, money int)

2、三张表,分别插入测试数据,

insert into pw_members values(1, 1)

insert into pw_members values(1, 2)

insert into pw_members values(1, 3)

insert into pw_memberinfo values(1, 'name_1')

insert into pw_memberinfo values(2, 'name_2')

insert into pw_memberinfo values(3, 'name_3')

insert into pw_memberdata values(1,30,50,150)

insert into pw_memberdata values(2,77,50,12)

insert into pw_memberdata values(3,44,50,82)

3、查看pw_memberdata表中的记录,select * from pw_memberdata t,

4、编写sql语句,

select * from (SELECT i.uid, sum(deposit+ddeposit+money) as allmoney

FROM pw_memberinfo i

LEFT JOIN pw_members m ON m.uid=i.uid

LEFT JOIN pw_memberdata d ON i.uid=d.uid

group by i.uid

) t where allmoney>200

SELECT i.uid,sum(deposit+ddeposit+money) as allmoney FROM

另外,因为你是多个表的左联接,考虑到有NULL记录的存在,建议你用函数ifnull处理下,避免由于NULL而造成结果有误,最终改成这样:

SELECT i.uid,sum(ifnull(deposit,0)+ifnull(ddeposit,0)+ifnull(money,0)) as allmoney

FROM pw_memberinfo i LEFT JOIN pw_members m ON m.uid=i.uid LEFT JOIN pw_memberdata d ON i.uid=d.uid

where ifnull(deposit,0)+ifnull(ddeposit,0)+ifnull(money,0)>2000

你好,很高兴回答你的问题。

直接修改一下你的这个语句就可以。

在第一个箭头所指的位置加上"sum(",在第二个箭头所指的位置加上后半个括号")"。执行修改后的sql就可以达到你想要的结果了。

如果有帮助到你,请点击采纳。

我解答的大部分都是软件开发新人遇到的问题,如果有兴趣可以关注我。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6136466.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-16
下一篇 2023-03-16

发表评论

登录后才能评论

评论列表(0条)

保存