存储来自 2 个表 Laravel 的外键值

Posted

技术标签:

【中文标题】存储来自 2 个表 Laravel 的外键值【英文标题】:Storing Foreign Key values from 2 tables Laravel 【发布时间】:2017-07-26 04:25:10 【问题描述】:

我有 3 个模型 - 用户、订单和零售商 我为用户创建了一个表单来下订单。 订购单有两个选择框。 第一个是选择具有所有用户 ID 的用户 第二个是选择具有所有零售商 ID 的零售商 然后我有一个文本框来输入订单金额。

在提交表单时,我收到以下错误。 SQLSTATE[23000]:完整性约束违规:1452 无法添加或更新子行:外键约束失败(shop.orders,CONSTRAINT orders_user_id_foreign FOREIGN KEY (user_id) REFERENCES users (@987654326 @)) (SQL: 插入orders (total, updated_at, created_at) 值 (10, 2017-03-06 10:22:43, 2017-03-06 10:22:43) )

有人可以帮我理解如何将用户表、零售商表中的外键值存储到订单表中吗?

我的存储方法:

$data = \Input::only("name", "retailer", "total");
    $order = new Order($data);
    $order->save();
    return redirect("orders");

创建订单:

!! Form::open(array("url"=>"orders", "class"=>"form-horizontal")) !!

    <div class="form-group">
        !! Form::label("name", "Select User", array("class"=>"col-md-2")) !!
        <div class="col-md-10"> 
        !! Form::select('id', $users, null, ['class' => 'form-control']) !!
        </div>
    </div>

    <div class="form-group">
        !! Form::label("retailer", "Select Retailer", array("class"=>"col-md-2")) !!
        <div class="col-md-10"> 
        !! Form::select('id', $retailers, null, ['class' => 'form-control']) !!
        </div>
    </div>

    <div class="form-group">
        !! Form::label("total", "Enter total", array("class"=>"col-md-2")) !!
        <div class="col-md-10"> 
        !! Form::text("total","",array("placeholder"=>"Enter total", "class="=>"form-control")) !!
        </div>
    </div>

    <div class="form-group">
        <div class="col-md-2"> !! Form::submit('Order', array("class"=>"btn btn-primary","id"=>"btn")) !! </div>
        <div class="col-md-10"><a href="url('/orders')" class="btn btn-success">Back..</a></div>
    </div>


    !! Form::close() !!

【问题讨论】:

【参考方案1】:

您可以使用关系或手动添加用户 ID。例如,如果你想让当前用户与订单相关:

$order = new Order($data);
$order->user_id = auth()->user()->id;
$order->save();

【讨论】:

然后我将如何处理将retailerId 存储到作为来自零售商表的外键的订单表中? @Jay240692 您没有提供任何与零售商相关的代码。如果retailer_idorders 表中有retailer_id,您可以像使用user_id 一样手动填写它 太棒了 - 成功了!我添加了 $order->retailerId = $request->get('id');

以上是关于存储来自 2 个表 Laravel 的外键值的主要内容,如果未能解决你的问题,请参考以下文章

更改主键值

如何编写一个查询,根据 ms 访问的子表中的外键获取信息?

MySQL:数据管理

sql中外键怎么写?

最初在 django 内联表单集中设置不同的外键值

是否可以将一个表中的主键引用为超过 2 个表的外键约束?