Moh*_*que 5 database-design invoice
在开票应用程序中,请考虑以下事项:
我有一个产品表,其中也包含产品的价格.然后我有一张发票和invoice_lines表,在每个发票行中,我都会参考产品ID和数量.在这种情况下,我不会将产品的价格与发票行一起存储.
现在几个月后,如果产品价格发生变化,任何报告都会根据当前价格而不是实际销售产品的价格显示销售量.
我想到的一个解决方案是,我们保留一个名为价格的单独表格,链接到每个产品,每当产品价格发生变化时,记录就会插入此价格表中.此表中的最新记录始终被视为新发票的当前价格.每个发票行通过指示价格的ID来指示其价格,以便稍后在报告中正确显示.
处理此类情况的最佳做法是什么?
我总是会在购买时存储每个订单商品的实际名称,数量和价格,从而有效地对数据进行反规范化.订单是及时拍摄的,不应与可能发生变化的事物相关联.价格不仅会波动,而且如果您删除或重命名原始产品并且您的发票与之相关,会发生什么?