【问题标题】:Laravel soft delete at User model not working用户模型上的 Laravel 软删除不起作用
【发布时间】:2017-10-16 09:10:54
【问题描述】:

我正在使用 Laravel 5.4。

我将软删除添加到用户模型。

喜欢use SoftDeletes$dates = ['deleted_at']

当我使用User::destroy(1) 时,它实际上会在数据库中添加deleted_at 值,所以我确定SoftDeletes 没有设置问题。

但是当我获取用户列表并使用用户模型登录时,它不会过滤已删除的行。

有人遇到同样的问题吗?请告诉我你是如何解决这个问题的。

--更新--

应用\用户.php

<?php

namespace App;

use Illuminate\Database\Eloquent\SoftDeletes;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;
use Laravel\Passport\HasApiTokens;
use Laravel\Scout\Searchable;

class User extends Authenticatable
{
    /**
     * Added for passport - api login checking
     */
    use HasApiTokens, Notifiable, Searchable;

    use SoftDeletes;

    /**
     * The attributes that are mass assignable.
     *
     * @var array
     */
    protected $fillable = [
        'name',
        'email',
        'password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password',
    ];

    protected $dates = [
        'created_at',
        'updated_at',
        'deleted_at',
    ];
}

用户控制器.php

<?php

namespace App\Http\Controllers;

use App\Events\ErrorLog;
use App\Helpers;
use App\Http\Controllers\Controller;
use App\User;
use Validator;
use Illuminate\Http\Request;

class UserController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index(Request $request)
    {
        $fields = $request->fields ? $request->fields :
            [
                'id',
                'name',
                'email',
            ];

        $search = function ($query) {
            $query->where('name', 'like', '%' . request()->nameOrEmail . '%')
                ->orWhere('email', 'like', '%' . request()->nameOrEmail . '%');
        };

        $users = User::where($search)
            ->orderBy('id')
            ->paginate(20, $fields);

        return response()->json([
            'status' => 'success',
            'data' => $users,
        ]);
    }
}

【问题讨论】:

  • 您应该在此处提供您正在执行的操作的代码:“但是当我获取用户列表并使用用户模型登录时,它不会过滤已删除的行。”如果没有该代码,除了猜测之外,您将无法回答您的问题。
  • 能分享一下型号代码和获取用户列表的代码吗?

标签: php laravel laravel-5 eloquent laravel-5.4


【解决方案1】:

软删除过滤器仅适用于 eloquent ORM

如果您不使用 eloquent,即如果您使用查询构建器或一些原始 sql,则需要手动检查软删除

例如

$user= User::all(); //eloquent

相同
 SELECT 
      * 
    FROM
      users
    WHERE
      deleted_at IS NULL 

但不是为了

$users=DB::table('users') //non eloquent

这只是

SELECT * FROM users

在这种情况下你需要通过一些条件

DB::table('users')
            ->whereNull('deleted_at');

编辑

您使用了覆盖 eloquent 条件的查询生成器,请尝试以下操作

$users = User::where($search)
             ->whereNull('deleted_at')
            ->orderBy('id')
            ->paginate(20, $fields);

【讨论】:

  • 我使用的是用户而不是 DB::table('users'),你对此有什么想法吗?
  • 一点补充:whereNull('deleted_at')默认完成,无需包含。如果你想要删除的记录,你也可以这样做 ->withTrashed()
  • whereNull('deleted_at') 应该自动完成,但在我的情况下不是。可能是 Laravel 中的错误?我使用的是 5.4.22 版
  • 试试这个 User::find($id)->delete();
  • 截至 2019 年,使用 Laravel 6 问题仍然存在,但仅限于 User 类。有没有人知道为什么会这样? $user-&gt;delete();期间没有抛出异常用户只是以标准方式删除。
猜你喜欢
  • 2014-10-19
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-06-19
相关资源
最近更新 更多