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%
帮助的人:870万
展开全部
连接不建议做聚合操作,很容易出问题,一般这种都直接同步用户的消费金额,换句话说,就是再单独一份用户消费表,用户有消费的时候就增加这个字段的值。

或者把你的sql客房订单和餐饮订单分开写,不然就只有嵌套了,似乎没有这个必要
光点科技
2023-08-15 广告
通常情况下,我们会按照结构模型把系统产生的数据分为三种类型:结构化数据、半结构化数据和非结构化数据。结构化数据,即行数据,是存储在数据库里,可以用二维表结构来逻辑表达实现的数据。最常见的就是数字数据和文本数据,它们可以某种标准格式存在于文件... 点击进入详情页
本回答由光点科技提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式