- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试为多家公司生产的产品、他们的配件以及产品和配件与客户账户的关联设计一个数据库。
您将如何设计这样的数据库来实现此功能?
商业规则
我的方法
访问https://www.dropbox.com/s/mmxqzgagbw1sek1/Ejemplo.png?dl=0
为了实现只有现有的产品与配件/ bundle 的组合才能与用户限制相关联,我在代码中添加了以下业务规则:如果组合存在于 products_accessories 中,则该组合符合条件;否则代码将触发错误。
最后,为了使产品和配件/ bundle 的所有可能组合都符合条件,由产品和配件组成的表 (products_accessories) 具有以下复合主键:(id、product_id 和 accessory_id)。
例如:
我有 p1 产品和以下附加组件:a1、a2 和 a3。 a1 和 a3 可以合并。在此示例中,products_accessories 表如下所示:
| id | product_id | accessory_id |
|----|------------|--------------|
| 1 | p1_id | a1_id |
| 2 | p1_id | a2_id |
| 3 | p1_id | a3_id |
| 4 | p1_id | a1_id |
| 4 | p1_id | a3_id |
最佳答案
我建议采用“ Material list ”类型的方法。
+-------------+
| COMPANIES |
+-------------+
| #company_id |
+-------------+
|
+--------^--------+ +-----------------+ +------------+
| PRODUCTS |---< CLIENT_PRODUCTS >---| CLIENTS |
+-----------------+ +-----------------+ +------------+
| #product_id | | #client_id | | #client_id |
| #company_id | | #product_id | +------------+
| is_offereable | | #company_id |
+-----------------+ +-----------------+
| |
+---------------------+
| PRODUCT_BUNDLES |
+---------------------+
| #parent_product_id |
| #child_product_id |
| #company_id |
| quantity |
+---------------------+
company_id 作为 PRODUCTS PK 的一部分包含在内,因此只有来自同一公司的产品才能捆绑。
产品表最初包括单个产品和单个配件。来自同一家公司的个别产品和配件可能会捆绑在一起形成新的“产品”。这些新的“产品”可能会与单独的产品或配件或其他 bundle 捆绑在一起,形成更多的“产品”。
is_offerable 标志指示单个产品、配件或 bundle 是否可能与客户相关联。
您还可以通过在 PRODUCTS 表中添加产品类型列并确保只有 PRODUCT 类型的产品或包含至少一种 PRODUCT 的 bundle 与客户相关联,从而限制哪些产品与客户相关联。
关于mysql - 公司、产品、配件和协会的数据库设计,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25547712/
您好,我有一个用 cakephp 开发的网站。我有两张 table :成分属性 表之间的关系是 HasAndBelongsToMany(HABTM)。这是我的模型: class Ingredient
我从 sails.js 开始,我完全迷失了我的 sql 查询。 我有以下表格: genres +-----------+--------------+------+-----+ | Field
我正在开发一个 Rails 应用程序,用户可以在其中将他们希望执行的任务添加到他们自己的自定义列表中。每个任务也可以属于 0 个或多个类别。到目前为止,我已经试过了: 用户.rb has_one :u
我是新手。我正在尝试加入不同的集合以获取一些数据。我能够获取帖子创建者和喜欢的信息,但是如何使用 mongoose 中的关联获取包含他们的评论和评论者信息的帖子? 用户模式 const userSc
我试图让 mongoid 保存关联,但我只能让一侧工作。如果我有以下测试。 test "should add a user as a follower when a user follows th
我正在为 has_many 使用 FactoryGirl 示例来自 http://robots.thoughtbot.com/post/254496652/aint-no-calla-back-gir
我想为我的应用程序实现一个消息传递系统。 我有用户。 我应该怎么做? 创建一个带有外部两个用户外键的消息模型??.. 完成这项工作的最合适的方法是什么? 我担心的是,如果我查询“message.use
我正在尝试使用 FactoryGirl 创建一个测试数据库,该数据库的关联是 Parent has_many Entries。此时抛出Parent不能为空的ActiveRecord验证错误。我在这方面
我有以下关联 class Training 我也试过 FactoryGirl.define do factory :attendance do training associat
以下是我的制造商: Fabricator(:my_fabricator) do my_first_association my_second_association end 这里的问题是我需要
有关 Rails 关联的问题。 考虑以下模型: 人 事件 图片 人物和事件可以有很多图像。 上传到事件的图像需要具有与多人关联的能力。 这意味着人和图像之间存在两种关系。 一种将图像直接上传到人物身上
谁能告诉我 Android 应用程序开发与 Java 的关联有多密切。也就是说,从事 Android 开发的人员有可能从事 Core Java 或 J2EE 或 J2SE 的工作吗? 让我把我的问题说
从 Rails 4 和 Postgres 9 开始,引入了 array column。我还尝试使用数组列来存储诸如 tags 或 categories 之类的东西,我不经常更改它们,它用作搜索的引用/
我正在尝试从一对多关系创建一个序列化的 RESTful 响应。 我有一张表Lexicon,主键lexicon_id,我还有一张表lexicon_attributes,主键lexicon_attribu
协会的确切目的是什么?我了解关系的含义以及何时使用每种类型,例如: belongs_to, has_many, has_one , has_and_belongs_to_many, ect 但我不太明
最近我开始使用 Ruby on Rails 而不是 PHP 创建我的网站。 我已经很容易地掌握了这门语言,但仍然对联想没有 100% 的信心:) 我有这种情况: 用户模型 has_and_belong
我想用Sinatra和DataMapper做一个博客应用,我的主应用文件是这样的。 %w[rubygems sinatra data_mapper].each{ |r| require r } Dat
我有一个以前用于生产的 MySQL 数据库,现在我们的团队正在迁移到 SailsJS。我读过有关 sails 船协会的资料,我认为它很棒。但我想知道您是否可以使用关联来使用 .populate 方法填
我有一个模型 ShippingOption,它有_many ShippingSpeedOptions 还有一个要求: ShippingOption 必须有至少一个 ShippingSpeedOptio
好的,这是我的问题。我有 3 种不同的模型,人员、角色、客户和商店。客户有很多商店,也可以有很多人。商店有很多人。人有不同的角色。 1 人可以在多家门店工作,在每家门店可能担任不同的角色。 例如。 J
我是一名优秀的程序员,十分优秀!