- 批量删除
- 上一节增删改中,新增中我们发现需要进行批量赋值的许可;
- 一般情况下,是为了防止提交过来的字段在部分场景中不需要或不能;
- 所以,我们需要通过黑白名单机制进行过滤必要的字段
//通过提交过来的数据一次性新增
User::create(\Request::all());//里面的 \Request::all() 就是拿到所有浏览器上面拿到的
- 软删除
- 什么叫软删除?它相对于真实的删除,并非真正的删除,只是隐藏:
- 首先,需要在数据库创建一个字段deleted_at(默认),用于判断是否被软删除;
- 默认设置这个字段为空(null),如果写入数据,成为非空状态,则说明被删除;
- 开启软删除的功能,需要在模型端设置一下:
//开启软删除功能
use SoftDeletes;
e. 当开启了软删除功能,之前的删除操作,都会变成更新操作,给deleted_at赋值;
//删除一
$users = User::find(23);
$users->delete();
//删除二
User::destroy(27);
f. 而当我们开启了软删除功能后,此时通过正常的数据获取列表,会自动隐藏;
//软删除的数据不可见
$users = User::get();
return [$users];
//单独获取被软删除的数据不行
$users = User::find(27);
return [$users];
g. 如果需要查询包含软删除的数据,通过witTrashed()方法实现;
//获取包含软删除的数据
$users = User::withTrashed()->get();
return [$users];
//获取某个被软删除的数据(即使不是软删除的也可以搜索到)
$users = User::withTrashed()->find(27);
return [$users];
h. 如果只想搜索出被软删除的数据,通过onlyTrashed()方法实现;
//获取所有被软删除的数据
$users = User::onlyTrashed()->get();
return [$users];
//获取某个被软删除的数据(只有软删除的数据才可以被搜索到)
$users = User::onlyTrashed()->find(23);
return [$users];
i. 如果要对这个数据进行软删除的判断,是否是被软删除的,可以使用trashed();
//判断是否是被软删除的数据,如果是被软删除的,那么就会返回1
$users = User::withTrashed()->find(23);
return $users->trashed();
j. 如果想将软删除的数据恢复正常(类似从回收站还原),使用restore()方法;
//将软删除的数据回复正常
$users = User::onlyTrashed()->find(23);
$users->restore();
k. 如果开启了软删除,还需要强行真实的永久删除,可以使用forceDelete()方法;
//开启软删除时的真实永久删除
$users = User::onlyTrashed()->find(27);
$users->forceDelete();