我收到了这个错误
传递给Illuminate \ Database \ Grammar :: parameterize()的参数1必须是数组类型,给定字符串,
当我尝试使用选择表单在我的视图中添加array[]
时。但是当我删除它时,我没有得到任何错误。我只是想在我的选择列表中输入一个多值。我需要使用foreach
吗?
查看
<div class = "form-group {{ $errors->has('approver') ? ' has-error' : '' }}">
<label for = "approver" class = "control-label">Approver:</label>
<select name = "approver[]" multiple class = "form-control select2-multi">
@foreach ($approver as $list)
<option value = "{{ $list->id }}">{{ $list->username }}</option>
@endforeach
</select>
@if ($errors->has('approver'))
<span class = "help-block">{{ $errors->first('approver') }}</span>
@endif
</div>
控制器
public function getDocuments()
{
$approver = DB::table('users')->where('id', '!=', Auth::id())->get();
return view ('document.create')->with('approver', $approver);
}
public function postDocuments(Request $request)
{
$this->validate($request,
[
'title' => 'required|regex:/(^[A-Za-z0-9 ]+$)+/|max:255',
'content' => 'required',
'category' => 'required',
'recipient' => 'required',
'approver' => 'required',
]);
$document = new Document();
$approve = new Approve();
$user = Auth::user();
//Request in the form
$document->title = $request->title;
$document->content = $request->content;
$document->category_id = $request->category;
$approve->approver_id = $request->approver;
$approve->save();
$document->save();
$document->sentToApprovers()->sync([$approve->id],false);
}
更新
我死了并转储$approver
变量并给出一个值数组。
同样死亡并转储$request
正如您在此处所见,我在选择列表中输入了 4 和 5 的ID。
答案 0 :(得分:8)
好的,您的问题是您尝试将数组保存为单数值,而您需要迭代批准者。
将控制器逻辑更改为:
foreach ($request->approver as $approver) {
$approve = new Approve();
$approve->approver_id = $approver;
$approve->save();
$document->sentToApprovers()->sync([$approve->id],false);
}
答案 1 :(得分:2)
就我而言,我想插入批量数据,因此出现错误。 然后我用了
User::insert($arrayData)
我完成了。
答案 2 :(得分:0)
在我的情况下,我没有在:-
中提及该名称$request->input();
所以我随便改变
$request->input("name");
然后它的作品
答案 3 :(得分:0)
我收到此错误是因为我在模型中重写了构造函数。如果这样做,请确保传递参数数组:
public function __construct(array $attributes = [], $something_else)
{
parent::__construct($attributes);
//...
$this->something_else = $something_else;
}