繁体   English   中英

Laravel 5如何在单个查询中插入(多个)两个相关表

[英]Laravel 5 How to insert (multiple) two related table into a single query

我有一张桌子,是OrderProduct

  • 订单表:id,order_name
  • 产品表:id,orders_id,product_name

在我的模型中: Order可以有很多products Product属于order

以下是我的看法:

<input type="text" name="order_name"> 
<input type="text" name="product_name">

<input type="text" name="order_name"> 
<input type="text" name="product_name">

从上面的视图中,我有两种形式,用户可以通过两个输入添加两个形式。

现在我的问题是如何在控制器中编写逻辑?

我只知道写多个产品插入一个订单的方法。 但是我不知道如何在相关产品中插入多个订单。

您应该使用数据透视表,因为这是两个表之间的多对多关系。

由于一个产品不仅属于一个订单,而且属于多个订单,并且一个订单可以具有许多产品,因此枢纽分析台是必经之路。

如果您不知道数据透视表是什么,请参见此处: http : //laraveldaily.com/pivot-tables-and-many-to-many-relationships/

他们在与您非常相似的示例中对此进行了解释。

尝试这个:

$order = new Order();
$order->order_name = $request->order_name;

if($order->save()) {
   $product = new Product();
   foreach($request->product_name as $product) {
     $product->product_name = $product;
     $product->order_id = $order->id;
     $product->save();
   }
}

暂无
暂无

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

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