thinkphp视图模型3张表联合查询

有一张用户表member,一张客房订单表order,一张餐饮订单表repast现在我需要查询所有的用户,并且把他们的客房和餐饮消费全部汇总,最后查询到的结果应该是用户表字... 有一张用户表member,一张客房订单表order,一张餐饮订单表repast
现在我需要查询所有的用户,并且把他们的客房和餐饮消费全部汇总,最后查询到的结果应该是
用户表字段1,用户表字段2,用户表字段3...........客房消费总额,餐饮消费总额
请问我如果要用thinkphp的视图模型应该怎么写,如果没有用过thinkphp的朋友,直接用sql应该怎么写啊
select member.*,sum(order.total_amount) as total,sum(repast.total_amount) as repast_total from member left JOIN order on member.id=order.member_id
left JOIN repast on member.id = repast.member_id
group by member.id
这样写出来的数据有错误,如果餐饮有10条数据,最后的结果客房总消费会乘以10
展开
 我来答
zhao61
2014-05-16 · TA获得超过1459个赞
知道小有建树答主
回答量:1065
采纳率:0%
帮助的人:858万
展开全部
连接不建议做聚合操作,很容易出问题,一般这种都直接同步用户的消费金额,换句话说,就是再单独一份用户消费表,用户有消费的时候就增加这个字段的值。

或者把你的sql客房订单和餐饮订单分开写,不然就只有嵌套了,似乎没有这个必要
七鑫易维信息技术
2024-09-02 广告
Play Video 七鑫易维是致力于机器视觉和人工智能领域的高新科技企业,迄今已专注眼球追踪技术的研发、创新与应用超过14年,拥有完全自主知识产权,全球专利总量500余项。 作为眼球追踪技术领域的全球知名品牌,七鑫易维的产品体系覆盖眼动分... 点击进入详情页
本回答由七鑫易维信息技术提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式