当前位置:Gxlcms > PHP教程 > 多表查询能统计排序,怎么写

多表查询能统计排序,怎么写

时间:2021-07-01 10:21:17 帮助过:25人阅读

会员表A 字段: userid,username
内容:
1 张三
2 李四


消费记录表B 字段: userid,username,money,type
内容:
1 张三 100 1
1 张三 100 1
2 李四 100 1
2 李四 100 2


要求:按type=1类型显示各个会员的总消费,并按消费金额排序

结果如:
张三 200元
李四 100元


回复讨论(解决方案)

select t.username,sum(t.money) as sum1
from table t
where t.type=1
group by t.username
order by sum1 desc

select sum(b.money) from b left join a.userid=b.userid where b.type=1 order by sum(b.money) desc

select username,sum(money) as total from 消费记录表B where type=1 group by username order by total desc

$strsql="select * from B where type=1"; $result=mysql_db_query($mysql_database, $strsql, $conn); mysql_data_seek($result, 0); $re = array();while ($row=mysql_fetch_row($result)) { 	isset($row['userid']) && $re[$row['userid']] += $row['money'];	isset($row['userid']) || $re[$row['userid']] = $row['money'];} foreach($re as $key=>$value) {echo $value['username'].' '.$value['money'];}// 释放资源 mysql_free_result($result); // 关闭连接 mysql_close($conn); 


你的B表里边已经包含了A表的内容,有必要关联两个表吗

select username,sum(money) as total from 消费记录表B where type=1 group by userid order by total desc;

人气教程排行