简体   繁体   中英

Laravel Validation Unique values in column for another

I am trying to set a validation rule in my request so that names will be unique to years in Laravel 5.2 .

So far, I have this for the request:

<?php

namespace App\Http\Requests;
use Auth;
use App\Http\Requests\Request;

class AwardeeRequest extends Request
{
    public function rules()
    {
        return [
            'name'=>'required',
            'year'=>'required',
        ];
    }
}

And my controller:

<?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'));
    }

}

I tried what was suggested here: Laravel 4: Unique Validation for Multiple Columns but it fails when I update the year.

Turns out I was over-thinking it.

Here's the final code. I removed the validation back to the Request rules.

<?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'),
        ];
    }
}

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM