5

在发票应用程序中,请考虑以下事项:

我有一个产品表,其中还包含产品的价格。然后我有一个 invoice 和 invoice_lines 表,在每个发票行中,我参考产品 ID 和数量。在这种情况下,我没有将产品价格与发票行一起存储。

现在几个月后,如果产品的价格发生变化,任何报告都会显示基于当前价格的销售量,而不是产品实际销售的价格。

我想到的一个解决方案是,我们保留一个名为价格的单独表,该表链接到每个产品,并且每当产品的价格发生变化时,都会在此价格表中插入一条记录。此表中的最新记录始终被视为新发票的当前价格。每个发票行通过指示价格的 ID 来指示其价格,以便稍后在报告中正确显示。

处理此类情况的最佳做法是什么?

4

3 回答 3

5

我总是会在购买时针对每个订单项目存储实际名称、数量和价格,从而有效地对数据进行反规范化。订单是及时的快照,不应与可能发生变化的事物相关联。不仅价格会波动,而且如果您删除或重命名原始产品并且您的发票与之相关,会发生什么情况?

于 2010-08-12T16:29:41.167 回答
1

将价格字段添加到发票行。

于 2010-08-12T16:26:49.710 回答
1

我会回应您的建议:将价格分解为包含这些列的单独表格:

PriceId、ProductId、价格、开始日期、结束日期。

这样,您还可以提前计划未来的价格变化。可以使用(Sql Server 语法)获取当前数据:

SELECT *
FROM Products
   Inner Join Prices ON Products.ProductId = Prices.ProductId 
      And GetDate() Between StartDate and EndDate
于 2010-08-12T18:09:01.433 回答