建表疑惑

需求

物业收费一般有两种。一种是物业管理费,一种是水电费。

物业管理费:房间面积*物业费收费标准

水电费:抄表用量*水电费收费标准
我对订单子项建表那里有疑惑。
下面是我建的表结构(简略版):

物业费表 PropertyManagementFee

id area(建筑面积) price(物业费收费标准) money(合计金额)
1 10 7 70

水电费抄表表 MeterReading

id last_month_reading(上月读数) this_month_reading(本月读数) price(水电费收费标准) money
1 0 10 3 30

订单表 Order

id no(订单号) total(合计金额)
1 x200022 100

订单子项表 OrderItem

id order_id property_management_fee_id(物业费id) meter_reading_id(水电费抄表id)
1 1 1
1 1 1

这里我对订单子项表那里有些疑惑。如果我要查订单子项表(OrderItem)的详细信息有时要联结物业费表(PropertyManagementFee),有时要联水电费抄表表(MeterReading),我想到的办法是同时联结两个表。大家面对这种有时要联结这个表,有时要联结那个表是怎么处理的?还是说这样建表是不合理的,有其他更好方法。

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
最佳答案

可以考虑使用多态关联吧。OrderItem就改成:

   id 
   order_id
   feeable_id 
   feeable_type
3年前 评论
zerocoder (楼主) 3年前
讨论数量: 3

可以考虑使用多态关联吧。OrderItem就改成:

   id 
   order_id
   feeable_id 
   feeable_type
3年前 评论
zerocoder (楼主) 3年前
  • 这要动手实战,你得找一堆,做同样项目的人讨论,大家各拿出一套方案然后总结。
  • 不好意思,我估计没人能听懂你的表述了,因为能接到物业公司的活我感觉要不就算万科这种,要不就是外包公司
3年前 评论
Jennie
3年前 评论
zerocoder (楼主) 3年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!