[英]Laravel Validation Unique values in column for another
我正在嘗試在請求中設置驗證規則,以使names
在Laravel 5.2
對於years
是唯一的。
到目前為止,我有這個要求:
<?php
namespace App\Http\Requests;
use Auth;
use App\Http\Requests\Request;
class AwardeeRequest extends Request
{
public function rules()
{
return [
'name'=>'required',
'year'=>'required',
];
}
}
而我的控制器:
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Awardee;
use App\Http\Requests;
class AwardeeController extends Controller
{
.
.
public function store(Requests\AwardeeRequest $request)
{
$this->validate($request, [
'name' => 'unique:awardee,name,NULL,year,year,' .$request->get('year'),
]);
return redirect(route('awardees.index'));
}
public function update(Requests\AwardeeRequest $request, $id)
{
$awardee = Awardee::findOrFail($id);
$this->validate($request, [
'name' => 'unique:awardee,name,NULL,year,year,' .$request->get('year').',id,id,'.$awardee->id,
]);
$awardee->fill($request->all())->save();
return redirect(route('awardees.index'));
}
}
我嘗試了這里提出的建議: Laravel 4:多列的唯一驗證,但是當更新年份時失敗。
原來我想得太多了。
這是最終代碼。 我將驗證移回了“請求”規則。
<?php
namespace App\Http\Requests;
use Auth;
use App\Http\Requests\Request;
class AwardeeRequest extends Request
{
public function rules()
{
return [
'year'=>'required',
'name'=>'required|unique:awardee,name,'.$this->get('id').',year,year,' .$this->get('year'),
];
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.