首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

通过 Laravel Eloquent 模型实现批量赋值和软删除

在上一篇教程中,我们基于 Eloquent 模型实现了对数据表记录的增删改查操作,今天我们在此基础上介绍两个 Eloquent 模型提供的高级功能 —— 批量赋值和软删除。...作为一个成熟的 ORM 框架,Eloquent 在设计之初肯定不会没有考虑到这样的问题,实际上,我们可以借助模型类中的白名单属性或黑名单属性来解决这个困扰。...Eloquent 模型类默认白名单属性为空,黑名单属性为 *,即所有字段都不会应用批量赋值: /** * 使用批量赋值的属性(白名单) * * @var array */ protected $...实现原理 Eloquent 模型类为我们提供了「软删除」功能的支持。这就意味着,在 Laravel 中,我们不需要编写任何额外代码就可以实现对数据库记录的「软删除」。...要软删除一条记录,在对应模型类实例上调用 delete 方法即可,底层会自动将数据表的 deleted_at 字段设置为当前时间,表示该记录已经被「删除」。

2.3K10

Laravel 5 系列入门教程(一)【最适合中国人的 Laravel 教程】

软件版本:PHP 5.4+,MySQL 5.1+ 本文不推荐完全不懂 PHP 与 MVC 编程的人学习。本文不是 “一步一步跟我做” 教程。...本系列教程为入门教程,目的是搞清楚 Laravel 的基本使用方法,切忌本末倒置。 然后将网站根目录配置为 learnlaravel5/public。 如果你不会配置,建议去学会配置,网上资料很多。...模型 Models 接下来我们将接触Laravel最为强大的部分,Eloquent ORM,真正提高生产力的地方,借用库克的一句话:鹅妹子英!...如果你想深入地了解 Eloquent,可以阅读系列文章:深入理解 Laravel Eloquent(一)——基本概念及用法 ---- 接下来进行 Article 和 Page 类对应的 articles...\Page; class PageTableSeeder extends Seeder { public function run() { DB::table('pages')->delete

3.4K20

3分钟短文:Laravel说要用软删除,可不要真删

引言 我们不止一次在系列文章中讲到模型的“软删除”功能,因为现实场景中为了保证数据可追溯,我们几乎不会对数据库进行物理删除删除数据有可能会造成数据一致性的破坏,进而导致业务逻辑无法跑通。...真实的SQL如下: DELETE FROM events WHERE id = 12; laravel提供了许多语法糖,上面使用 find 和 delete 两个步骤,可以缩减为一个方法 destroy...软删除 在许多情况下,你不会真正想要从数据库中删除记录,而是用一种不再在应用程序中显示它们的方式对其进行注释。这就是所谓的软删除。...Laravel本身支持软删除,只需要进行少量的配置更改,以确保在执行delete或destroy时,模型的记录不会被实际删除。作为一个例子,我们修改Event模型以支持软删除。...namespace App; use Illuminate\Database\Eloquent\Model; use Illuminate\Database\Eloquent\SoftDeletes;

2.1K00

laravel框架数据库操作、查询构建器、Eloquent ORM操作实例分析

本文实例讲述了laravel框架数据库操作、查询构建器、Eloquent ORM操作。...,['sandy',19]); //删除一条数据 DB::delete('delete from student where name=?'...DB::table('student')- where('id',' =',1006)- delete(); //删除整个表 DB::table('student')- truncate(); //修改数据...Laravel内置的Eloquent ORM提供了一种便捷的方式帮助你组织数据库数据,每张数据表都对应一个与该表进行交互的模型(Model),通过Model类,你可以对数据表进行查询、插入、更新、删除等操作...,一是通过find方法删除指定主键,二是通过查询构建器: //destroy删除指定主键值 Student::destroy(1006,1007); //通过查询构建器删除 Student::where

13.3K51

Laravel5.7 Eloquent ORM快速入门详解

删除一个模型,调用模型实例上的 delete 方法: $flight = App\Flight::find(1); $flight- delete(); 通过主键删除模型 在上面的例子中,我们在调用...$deletedRows = App\Flight::where('active', 0)- delete(); 注:通过 Eloquent 进行批量删除时,deleting 和 deleted 模型事件在删除模型时不会被触发...,这是因为在进行模型删除不会获取模型。...); }); 现在,当调用模型的 delete 方法时,deleted_at 列将被设置为当前日期和时间,并且,当查询一个使用软删除的模型时,被软删除的模型将会自动从查询结果中排除。...Laravel 自带的软删除功能就使用了全局作用域来从数据库中拉出所有没有被删除的模型。编写自定义的全局作用域可以提供一种方便的、简单的方式来确保给定模型的每个查询都有特定的条件约束。

15K41

3分钟短文:Laravel 从软删除说到模型作用域的概念

代码时间 常规的删除操作分两步进行,一步是把数据从数据库中查询出来,使用laravel模型的方法, 则返回的是一个模型对象。第二步,调用模型对象的delete方法。...代码如下: $contact = Contact::find(5);$contact->delete(); 如果像上面的代码那样,已知数据条目的ID,那么可以直接使用destroy方法进行删除: Contact...上面的delete方法,destroy方法,都是对数据的物理删除。...所以引入了软删除的概念,就是在表内添加一个字段,用于标记,这一行条目是否算是删除状态。在laravel中, 这个软删除字段默认是 deleted_at。你也可以在模型中手动指定。...写在最后 本文从laravel模型的写操作删除动作,讲到了软删除的概念。进而引申出来本地作用域和全局作用域的使用。软删除几乎贯穿了我们应用的始终,需要大家勤学苦练。

1.3K30

Laravel基础

一、Laravel核心目录文件介绍 app:程序的核心代码和业务逻辑代码,其中的Http目录是我们业务逻辑的存放点 bootstrap:包含框架启动的和自动加载文件 config:包含所有程序中的配置文件..., [ 21, 'EnzoLiu' ]); 3.1.4 删除数据 (返回int 受影响行数) $result = DB::delete('delete from student where name...关键词: delete 删除数据 truncate 清空表,并将ID自增重置为0 示例代码: delete DB::table("表名")->where('条件')->delete(); truncate...ORM 删除数据 使用模型删除数据 通过主键值删除数据 根据指定条件删除数据 //1....$name }} 模板中执行php代码 {{ date('Y-m-D H:i:s', time()) }} 模板中强制输出 @{{ $name }} 字符串 @{{ $name }} 模板注释格,不会在查看源代码中显示

7.8K30

Laravel 5.2 文档 数据库 —— 起步介绍

1、简介 Laravel 让连接多种数据库以及对数据库进行查询变得非常简单,不论使用原生 SQL、还是查询构建器,还是 Eloquent ORM。...目前,Laravel 支持四种类型的数据库系统: MySQL Postgres SQLite SQL Server 配置 Laravel 让连接数据库和运行查询都变得非常简单。...默认情况下,Laravel 示例环境配置已经为 Laravel Homestead 做好了设置,当然,你也可以按照需要为本地的数据库修改该配置。...读/写连接 有时候你希望使用一个数据库连接做查询,另一个数据库连接做插入、更新和删除Laravel 使得这件事情轻而易举,不管你用的是原生 SQL,还是查询构建器,还是 Eloquent ORM,合适的连接总是会被使用..., ['John']); 运行删除语句 delete方法用于删除数据库中已存在的记录,和update一样,该语句返回被删除的行数: $deleted = DB::delete('delete from

3.2K71

Laravel框架关键技术解析

这个资源可以是一个类的实例、一个路径或是一个文件等,提供服务就是提供一种资源(Illuminate\Routing\ControllerServiceProvider.php) C.PHP中的特殊语法 1.魔术方法:通常用户不会主动调用...Laravel示例(Illuminate\Database\Eloquent\Model.php) 2.魔术常量:__LINE__、__FILE__、__DIR__、__FUNCTION__、__CLASS...示例:Illuminate\Database\Eloquent\Model.php,如query()方法中(new static)->newQuery(); F.Laravel中使用的其他新特性 1.trait...ORM 1.两个阶段 Eloquent ORM查询构造器的生成,Illuminate\Database\Eloquent\Model::newQuery() 操作命令的执行,Illuminate\Database...通过中间件StartSession开启会话 2.根据sessionID来恢复之前 存储的数据,在请求处理期间可以使用恢复的数据,同时也可以向session中继续添加或删除数据。

11.9K20

通过 Laravel Eloquent 模型实现简单增删改查操作

「ActiveRecord」是 ORM 的一种实现模式,Eloquent 则是 Laravel 版的「ActiveRecord」。...通过模型类删除对应数据表记录和更新记录类似,都要先获取对应操作模型实例,删除对应记录更简单,获取到模型实例后,直接调用其删除方法即可: $post = Post::find(31); $post->delete...(); 这样,就完成了 id = 31 对应数据表记录的删除,你还可以通过 Eloquent 提供的 destroy 方法一次删除多条记录,通过数组传递多个主键 ID 即可: Post::destroy...([1,2,3]); 当然,你也可以通过查询构建器的方式删除指定记录: $user = User::where('name', '学院君')->fisrt(); $user->delete(); 结语...本系列教程首发在Laravel学院(laravelacademy.org)

7.9K20

Laravel学习笔记(四)——模型,更安全的数据存取

看了接下来的Laravel模型的使用之后你就会爱上LaravelEloquent ORM模型,这也是我直接介绍模型而不讲解其他数据库操作的原因。...Laravel 数据库配置 要想使用模型,第一个要设置的当然是数据库信息。...Eloquent ORM LaravelEloquent ORM 提供了漂亮、简洁的 ActiveRecord 实现来和数据库交互。每个数据库表都有一个对应的「模型」用来与该表交互。...$daming->name = 'daming';// 赋值字段名 $xiaoming->save();// 保存至数据库 $daming->save();// 保存至数据库 drop 获取对象 删除对象...$xiaoming = Student::find(1); $xiaoming->delete(); Eloquent ORM是通过调用laravel内置的方法来对数据库进行增删改查等操作的,这种方式很大程度上解决了数据库注入等安全问题

2K00
领券