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

时间:2017-03-06 10:32:07

标签: php html mysql laravel laravel-blade

我有3个型号 - 用户,订单和零售商 我已经为用户创建了一个表单来进行订单。 订单有两个选择框。 第一个是具有所有用户ID的选择用户 第二个是具有所有零售商ID的精选零售商 然后我有一个文本框输入订单金额。

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

有人可以帮我理解我如何将来自Users表,零售商表的外键值存储到Orders表中吗?

我的商店方法:

$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 个答案:

答案 0 :(得分:2)

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

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