十九、PHP框架Laravel学习笔记——批量赋值和软删除
一.批量赋值
- 上一节增删改中,新增中我们发现需要进行批量赋值的许可;
- 一般情况下,是为了防止提交过来的字段在部分场景中不需要或不能;
- 所以,我们需要通过黑白名单机制进行过滤掉必要的字段;
//通过提交过来的数据一次性新增
User::create(\Request::all());
二.软删除
- 什么叫软删除?它相对于真实的删除,而并非真正的删除,只是隐藏了;
- 首先,需要在数据库创建一个字段
deleted_at
(默认),用于判断是否被软删除; - 默认设置这个字段为空(null),如果写入数据,成为非空状态,则说明被删除;
- 开启软删除的功能,需要在模型端设置一下:
//开启软删除功能
use SoftDeletes;
- 当开启了软删除功能,之前的删除操作,都会变成更新操作,给 deleted_at 赋值;
//删除一
$users = User::find(82);
$users->delete();
//删除二
User::destroy(81);
- 而当我们开启了软删除的功能后,此时通过正常的数据获取列表,会自动隐藏;
//软删除的数据不可见
$users = User::get();
return [$users];//单独获取被软删除的数据不行 $users = User::find(82); return [$users];
- 如果需要查询包含软删除的数据,通过 withTrashed()方法实现;
//获取包含软删除的数据
$users = User::withTrashed()->get();
return [$users]; //获取某个被软删除的数据(即使不是软删除的也可以搜索到)
$users = User::withTrashed()->find(82);
return [$users];
- 如果只想搜索出被软删除的数据,通过 onlyTrashed()方法实现;
//获取所有软删除的数据
$users = User::onlyTrashed()->get();
return [$users]; //获取某个被软删除的数据(只有软删除的数据才可以被搜索到)
$users = User::onlyTrashed()->find(82);
return [$users];
- 如果要对这个数据进行软删除的判断,是否是被软删除的,可以使用 trashed();
//判断是否是被软删除的数据 $users = User::withTrashed()->find(81); return $users->trashed();
- 如果想将软删除的数据恢复正常(类似从回收站还原),使用 restore()方法;
//将被软删除的数据回复正常
$users = User::onlyTrashed()->find(82);
$users->restore();
- 如果开启了软删除,还需要强行真实的永久删除,可以使用 forceDelete()方法;
//开启软删除时的真实永久删除
$users = User::onlyTrashed()->find(82);
$users->forceDelete();
十九、PHP框架Laravel学习笔记——批量赋值和软删除相关推荐
- 三十、PHP框架Laravel学习笔记——模型的预加载
一.预加载 预加载,就是解决关联查询中产生的 N+1 次查询带来的资源消耗 我们要获取所有书籍的作者(或拥有者),普通查询方案如下: //获取所有书籍列表 $books = Book::all(); ...
- 十、PHP框架Laravel学习笔记——数据库配置入门
一.配置数据库 框架支持原生.查询构造器和 Eloquent ORM(关系型对象映射器)来操作数据库: 数据库的配置在 config/database.php,如果是本地可以直接配置.env 文件: ...
- 二十、PHP框架Laravel学习笔记——模型的作用域
一.本地作用域 很多情况下,我们在数据查找时有一部分条件会被重复且大量使用: 而这个条件,可能只是在这个模型对应的数据表使用,别的表并不使用: 那么这种情况,可以使用本地作用域的方式,将常用的 SQL ...
- 十八、PHP框架Laravel学习笔记——模型的增删改
一.增删改操作 新增方法如下,注意:默认模型接管 created_at 和 updated_at: $users = new User(); $users->username = '辉夜'; $ ...
- 深度学习(二十九)Batch Normalization 学习笔记
Batch Normalization 学习笔记 原文地址:http://blog.csdn.net/hjimce/article/details/50866313 作者:hjimce 一.背景意义 ...
- 二十九、PHP框架Laravel学习笔记——Debugbar 调试器
二.安装使用 通过 composer 在项目中安装 Debugbar,命令如下: composer require barryvdh/laravel-debugbar 生成一个配置文件,给用户配置,可 ...
- 二十二、PHP框架Laravel学习笔记——集合的使用
一.创建集合 什么是集合?即:它是一种更具读取性和处理能力的数组封装: 比如,我们从数据库得到的数据列表,它就是一种集合: 数据集合,提供了大量的方法方便我们进行各种操作: 除了数据库对象返回的数据集 ...
- 二十八、PHP框架Laravel学习笔记——模型的关联查询
二.关联查询 前几篇博文,了解了三种基础的关联模型,并简单的进行查询: 本节课,我们详细的了解更多的查询方案: //下面两种查询是一样的: $books = User::find(19)->bo ...
- 二十六、PHP框架Laravel学习笔记——模型的一对多关联
二.一对多关联 一对多关联,本质上使用方法和一对一关联类似,内部实现略有不同: 创建另一个模型:book.php,我们看下这个表数据: PS:这里 user_id=19 有三个,也就是蜡笔小新有三本书 ...
最新文章
- 深度学习、AI构图、智能裁图、显著性检测、美感质量评价
- 零基础学python语言_零基础如何入门Python语言?有哪些学习建议?
- 文件 服务器 要求,文件服务器硬件要求
- 加强数据中心安全的六条措施
- 修改RAC VIP IP
- 面试官:说说你对高性能秒杀系统的设计思考?
- es6分享——变量的解构赋值
- python实现目录中制定内容查找
- 如何打开.jar文件?
- sqlserver字符串拼接
- 解决ios微信小程序弹框点击穿透问题
- UNITY读取图片素材的URL并使用
- ANSYS win10家庭版安装经验:
- Excel·VBA考勤打卡记录统计结果
- 扯淡扯着扯着就远了----关键字;宁静致远
- python支付宝二维码支付源代码
- 枪花--DON'T CRY
- 一只青蛙一次可以跳上1级台阶也可以跳上2级求该青蛙跳上一个n级的台阶总共有多少种跳法
- 计算机教学能力提升体会,学习《信息技术助力教学能力提高》感悟
- cron每小时执行一次的表达式
热门文章
- CentOS7 安装或迁移 wordpress(完整迁移)
- promise用法_Promise的秘密
- python中none是什么类型_如何在Python中”测试”None类型?
- 安装cocoa pods时出现Operation not permitted - /usr/bin/xcodeproj的问题
- 第一季5:Hi3518EV200的环境搭建
- LeetCode344——Reverse String(将字符串反转)
- [源码和文档分享]基于C语言的语法高亮设计与实现
- cas-client登录后报INVALID_PROXY_CALLBACK
- 【娱乐】收录各种神奇知乎问答
- 删掉SQL Server登录时登录名下拉列表框中的选项