这是在这种特定情况下确保数据完整性的好解决方案吗?

发布于 2024-10-20 13:25:32 字数 799 浏览 7 评论 0原文

我正在开发一个跟踪某些商品价格的应用程序。

每个价格都参考了某个商品、销售该商品的企业以及该商品的销售地点。现在,通常情况下,这会很好:

CREATE TABLE `price` (
  `priceId` INT UNSIGNED NOT NULL AUTO_INCREMENT, -- PK
  `businessId` INT UNSIGNED NOT NULL,
  `itemId` INT UNSIGNED NOT NULL,
  `locationId` INT UNSIGNED NOT NULL,
  `figure` DECIMAL(19,2) UNSIGNED NOT NULL,
  -- ...
)

但我有以下问题:

应用程序逻辑是这样的,即一个地点的一个企业的一件商品可以有多个价格(此时,原因并不重要),并且其中之一价格可以是官方价格 - 一件商品不必有官方价格,但如果有的话,也只能有一个。

问题是;如何对此进行建模以确保数据完整性?


我最初的想法是创建一个附加表:

CREATE TABLE `official_price` (
  `priceId` INT UNSIGNED NOT NULL -- PK + FK (references price.priceId),
  -- ...
)

该表将保存官方价格的 PriceId:s,并且 PK/UNIQUE 约束将处理“一或无”约束。

这似乎是一个可行的解决方案,但我仍然想知道是否有更好的方法来处理这种情况?

I'm working on an application which tracks prices for certain items.

Each price has a reference to an item, a business that sells that item, and the location the item is being sold at. Now, normally, this would do just fine:

CREATE TABLE `price` (
  `priceId` INT UNSIGNED NOT NULL AUTO_INCREMENT, -- PK
  `businessId` INT UNSIGNED NOT NULL,
  `itemId` INT UNSIGNED NOT NULL,
  `locationId` INT UNSIGNED NOT NULL,
  `figure` DECIMAL(19,2) UNSIGNED NOT NULL,
  -- ...
)

But I have the following problem:

The application logic is such that one item at one business at one location can have multiple prices (at this point it's not really important why), and one of those prices can be an official price - an item doesn't have to have an official price, but if it does, there can be only one.

The question is; how to model this to ensure data integrity?


My initial idea was to create an additional table:

CREATE TABLE `official_price` (
  `priceId` INT UNSIGNED NOT NULL -- PK + FK (references price.priceId),
  -- ...
)

This table would hold priceId:s for prices that are official, and the PK/UNIQUE constraint would take care of the 'one-or-none' constraint.

This seems like a workable solution, but I'm still wondering if there's a better way to handle this situation?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

赠佳期 2024-10-27 13:25:32

您可以使用这个肮脏的黑客:

  1. 将一个字段 is_official 添加到 price 表中,因为其中可能存在值 null
  2. 创建一个唯一的复合索引 priceId + is_official code>
  3. 对于官方价格,将 1 设为 is_official
  4. 对于非官方价格,将其保留为 null

You can use this dirty hack:

  1. add a field is_official to price table, null as a value is possible in it
  2. create an unique composite index priceId + is_official
  3. for the official prices put 1 to is_official
  4. for not official left it to be null
梦晓ヶ微光ヅ倾城 2024-10-27 13:25:32

您可以使 price 表仅包含官方价格(数字可能为空),对 (businessId, itemId, < code>locationId),并添加另一个引用 priceId 的辅助价格表。

You could make the price table hold only official prices (with the figure possibly null), put a unique constraint on (businessId, itemId, locationId), and add another table of auxiliary prices referencing priceId.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文