首页 文章

laravel 4验证在两列上唯一[复制]

提问于
浏览
2

这个问题在这里已有答案:

嗨,我正在Laravel中进行一些验证,我想确保字段uid对于project_id是唯一的 . 例如我的数据库表如下:

id | project_id | uid        |
1  | 3          | task_uid   |
2  | 4          | task_uid2  |
3  | 4          | task_uid   |

uid可以在project_id中存在两次,但如果project_id相同则不能 .

我试过以下几点;

public static $rules = array(
    'UID' => 'required|unique:uid,project_id'
);

但是这没有用,并返回以下sql错误;

"SQLSTATE[42S02]: Base table or view not found: 1146 Table 'project.uid' doesn't exist (SQL: select count(*) as aggregate from `uid` where `project_id` = task_uid)"

我有什么想法可以检查任务表,以确保project_id和uid是唯一值?

1 回答

  • 5

    **请注意:这是Laravel 4 **

    独特的方式(在 laravel 4 ):

    unique:{tableName},{columnName}
    

    尝试

    public static $rules = array(
        'UID' => 'required|unique:{tableName},uid|unique:{tableName},project_id'
    );
    

    **请注意:这是为Laravel 4 ****

相关问题