Можете да напишете персонализирано правило за валидиране. Правилото може да изглежда така:
'unique_multiple:table,field1,field2,field3,...,fieldN'
Кодът за това би изглеждал така:
Validator::extend('unique_multiple', function ($attribute, $value, $parameters)
{
// Get table name from first parameter
$table = array_shift($parameters);
// Build the query
$query = DB::table($table);
// Add the field conditions
foreach ($parameters as $i => $field)
$query->where($field, $value[$i]);
// Validation result will be false if any rows match the combination
return ($query->count() == 0);
});
Можете да използвате колкото искате полета за условието, просто се уверете, че предадената стойност е масив, съдържащ стойностите на полетата в същия ред, както е деклариран в правилото за валидиране. Така вашият код за валидатор ще изглежда така:
$validator = Validator::make(
// Validator data goes here
array(
'unique_fields' => array('examdate_value', 'batch_value', 'chapter_value')
),
// Validator rules go here
array(
'unique_fields' => 'unique_multiple:exams,examdate,batch,chapter'
)
);