繁体   English   中英

Laravel模型关系

[英]Laravel Model Relationships

我在玩Laravel模型,遇到了一个相当普通的数据库设计模式,无法建立关系(使用Laravel)。

这是Database design

如果仅考虑下表(为简单起见):
1.客户
2.产品
3.Product_Prices(产品价格预计会随时间变化,我们需要保持跟踪)
4.Customer_Orders
5.Customer_Orders_Products(客户可以在一个订单中订购多个产品)

这是我到目前为止所拥有的:
1.产品HAS MANY Product_Prices
2. Product_Price BELONGS TO产品
3.客户HAS MANY Customer_Orders
4. Customer_Order BELONGS TO客户
5. CUSTOMER_ORDER HAS MANY Customer_Order_Products
6. Customer_Order_Products BELONGS TO Customer_Order的影响

我认为将通过与Products表建立关系来获取每个Customer_Order_ProductsPrice 我们如何建立这种关系?

如何获取具有以下详细信息的Laravel Collection Object (我不确定是否只有Eloquent返回一个集合对象,或者与Fluent相同):
1. Customer WITH Customer_Orders WITH Customer_Orders_Products WITH Product_Price

还有如何施加约束,例如:
1. Customer WITH Customer_Orders WITH Customer_Orders_Products WITH Product_Price WHERE Product_Price < Customers_Order.date_order_placed

谢谢

我认为取消规范化数据库以将价格包含在Customer_Order_Products中,然后使用以下关系将是更好的主意。

class CustomerOrder {
    protected $table = 'Customer_Orders';

    ...

    public function products()
    {
        return $this->belongsToMany('Products')->withPivot('quantity','comments', 'price');
    }

    ...
}

在您的情况下,Customer_Orders_Products不仅是精美的联接表,而且还具有与Product_Prices表之间的关系。

将product_price_id添加到表中,以将订购的产品映射到价格。

这增加了灵活性(也许价格是由以后的价格而不是“近期性”决定的),其间接费用几乎与直接存储价格相同。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM