簡體   English   中英

Laravel驗證另一個列中的唯一值

[英]Laravel Validation Unique values in column for another

我正在嘗試在請求中設置驗證規則,以使namesLaravel 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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM