Yu *_*ien 0 php laravel eloquent laravel-5 laravel-5.4
我正在使用Laravel 5.4.
我将软删除添加到用户模型.
喜欢use SoftDeletes和$dates = ['deleted_at']
当我使用User::destroy(1)它时实际上会在数据库中添加deleted_at值,所以我确定没有关于SoftDeletes的设置问题.
但是当我获得用户列表并使用用户模型登录时,它不会过滤删除的行.
有没有人有同样的问题?请告诉我你是如何解决这个问题的.
--Update--
应用程序\ user.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',
];
}
Run Code Online (Sandbox Code Playgroud)
UserController.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,
]);
}
}
Run Code Online (Sandbox Code Playgroud)
软删除过滤器仅适用于雄辩的ORM
如果您不使用eloquent,即如果您使用的是查询生成器或某些原始sql,则需要手动检查软删除
例如
$user= User::all(); //eloquent
Run Code Online (Sandbox Code Playgroud)
和...一样
SELECT
*
FROM
users
WHERE
deleted_at IS NULL
Run Code Online (Sandbox Code Playgroud)
但不是
$users=DB::table('users') //non eloquent
Run Code Online (Sandbox Code Playgroud)
这只是
SELECT * FROM users
Run Code Online (Sandbox Code Playgroud)
在这种情况下,您需要传递一些条件
DB::table('users')
->whereNull('deleted_at');
Run Code Online (Sandbox Code Playgroud)
编辑
您使用了覆盖eloquent条件的查询构建器,请尝试下面
$users = User::where($search)
->whereNull('deleted_at')
->orderBy('id')
->paginate(20, $fields);
Run Code Online (Sandbox Code Playgroud)