Laravel 4 - 如何使用多个字段验证唯一性


Laravel 4 - How to validate unique with multiple fields?

我有这个模式:

Schema::create('members', function(Blueprint $table)
    {
        $table->increments('id');
        $table->string('lname');
        $table->string('fname');
        $table->integer('mname');
        $table->unique(array('lname', 'fname'));
    });

我的问题是,如何验证这些独特的字段?

我试过这个,但我知道这是错误的...

public static $rules = array(
    'lname' => 'unique:members',
    'fname' => 'unique:members'
);

任何帮助不胜感激。 :)

你应该使用这个包 https://github.com/felixkiss/uniquewith-validator

像这样使用它:

$rules = array(
    '<field1>' => 'unique_with:<table>,<field2>[,<field3>,...,<ignore_rowid>]',
);

尝试以下操作:

public static $rules = array(
    'lname' => 'unique:members,lname',
    'fname' => 'unique:members,fname'
);

 'lname' => 'unique:members,lname',
                            ^^^^^ "lname" is a column of members table

更多信息:

http://laravel.com/docs/validation#rule-unique