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
1、创建一张表,同时插入数据。
2、按照价格排序.select * from 表名 order by 字段名 [升序|降序]。
3、按照class分组(group by),数据会分成三类,肉类、蔬菜类、水果类。
4、按照class分组后在对结果做一个处理,统计三个类总钱数分别是多少。这里sum是mysql提供的内置函数(聚合函数),统计合的。
5、分组了之后可以通过聚合函数可以做一系列的查询 *** 作,查询每个类中有多少个。
6、分组后面跟having做过滤。
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
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)