存储 2 个表中的外键值 Laravel
Storing Foreign Key values from 2 tables Laravel
我有 3 个模型 - 用户、订单和零售商
我已经为用户创建了一个表格来下订单。
订单有两个 select 框。
第一个是 select 拥有所有用户 ID 的用户
第二个是 select 零售商,它具有所有零售商 ID
然后我有一个文本框来输入订单金额。
提交表单时出现以下错误。
SQLSTATE[23000]:违反完整性约束:1452 无法添加或更新子行:外键约束失败(shop
.orders
,CONSTRAINT orders_user_id_foreign
FOREIGN KEY ( user_id
) 参考文献 users
(id
)) (SQL: 插入 orders
(total
, updated_at
, created_at
) 值 (10, 2017-03-06 10:22:43, 2017-03-06 10:22:43))
有人可以帮助我了解如何将来自用户 table、零售商 table 的外键值存储到订单 table 中吗?
我的店铺方法:
$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() !!}
您可以使用关系或手动添加用户 ID。例如,如果你想让当前用户与订单相关:
$order = new Order($data);
$order->user_id = auth()->user()->id;
$order->save();
我有 3 个模型 - 用户、订单和零售商 我已经为用户创建了一个表格来下订单。 订单有两个 select 框。 第一个是 select 拥有所有用户 ID 的用户 第二个是 select 零售商,它具有所有零售商 ID 然后我有一个文本框来输入订单金额。
提交表单时出现以下错误。
SQLSTATE[23000]:违反完整性约束:1452 无法添加或更新子行:外键约束失败(shop
.orders
,CONSTRAINT orders_user_id_foreign
FOREIGN KEY ( user_id
) 参考文献 users
(id
)) (SQL: 插入 orders
(total
, updated_at
, created_at
) 值 (10, 2017-03-06 10:22:43, 2017-03-06 10:22:43))
有人可以帮助我了解如何将来自用户 table、零售商 table 的外键值存储到订单 table 中吗?
我的店铺方法:
$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() !!}
您可以使用关系或手动添加用户 ID。例如,如果你想让当前用户与订单相关:
$order = new Order($data);
$order->user_id = auth()->user()->id;
$order->save();