Laravel Validator 更新时验证记录唯一的小技巧

2019-05-30 20:40:05 浏览数 (3)

比如我们在新增一篇文章的时候,我们一般会写如下的表单验证。

代码语言:javascript复制
$this->validate($request, [
    'title' => 'required|unique:article|max:255',
]);

这样在新增的时候是没什么问题的,但是在更新的时候就出现了一个问题,就是当我们的title没有发生改变的时候,我们使用unique的时候,会将原来的记录行进行扫描,这样就会提示我们该标题已经存在

这样就比较坑爹了,那么有没有什么办法可以解决呢。办法是有的,其实很简单,我们只需要跟下面那样写就好了:

代码语言:javascript复制
$id = $request->input("id", 0);
$this->validate($request, [
    'title' => "required|unique:article,id,{$id}|max:255",
]);

这样的话在验证唯一的时候就会不去验证id=$id的记录。这样就可以防止我们刚才碰到的问题了。

那么不管新增还是更新,套路就是这样了:

代码语言:javascript复制
$id = $request->input("id", 0);
$this->validate($request, [
    'title' => "required|unique:article,id,{$id}|max:255",
]);

if ($id < 1) { // 新增
    $info = new Article();
} else {
    $info = Article::where("id", $id)->first();
}

$info->title = $request->input("title");

if ($info->save()) {
    // 操作成功
} else {
    // 操作失败
}

Laravel真是最好的框架。

1 人点赞