日期:2014-05-17  浏览次数:20469 次

求助!!三表查询求和。



现在要做一个求积分的功能。用户上传一个图片一分,上传一个视频1分,上传一个音乐一分。现在有3个表分别存储图片,音乐,视频:(如上)
我应该怎么写sql语句实现查询出每个用户的积分呢?最好能帮我写下代码。或者,给点好的建议,谢谢。
------最佳解决方案--------------------
select userid,SUM(integral) as integral
from (
select userid,COUNT(1) as integral
from endurervideo
group by userid
union all
select userid,COUNT(1)
from endurermusic
group by userid
union all
select userid,COUNT(1)
from album
group by userid) as  a 
group by userid

------其他解决方案--------------------
三个表分别按条件求和,再相加
------其他解决方案--------------------
引用:
三个表分别按条件求和,再相加

代码。。。。
------其他解决方案--------------------
用户上传一个图片一分,上传一个视频1分,上传一个音乐一分。

用户上传一个,对应的表就有一条记录?
------其他解决方案--------------------
引用:
用户上传一个图片一分,上传一个视频1分,上传一个音乐一分。

用户上传一个,对应的表就有一条记录?
是的
------其他解决方案--------------------
4楼正解。

或者这样写


;with cte as(
select userid, count(1) tsum from endurervideo group by userid union all
select userid,count(1) tsum from endurermusic group by userid union all
select userid, count(1) tsum from album group by userid
)
select userid,sum(tsum) sSum from cte group by userid 


------其他解决方案--------------------
干的漂亮!

引用:
select userid,SUM(integral) as integral
from (
select userid,COUNT(1) as integral
from endurervideo
group by userid
union all
select userid,COUNT(1)
from endurermusic
group by use……