首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

laravel 模型Eloquent ORM 添加编辑删除

自动都变成了插入或者修改的时间了,这就是使用模型的好处一大好处 删除 但是最后的这个 deleted_at 是空的,这个字段应该怎么用呢?...当时我希望能有一个恢复删除的功能比如说回收站,laravel模型为我们提供了很方便的软删除功能 要启用软删除首先数据表需要有 deleted_at 字段 之前玩迁移的时候简单的说了下创建迁移的时候调用...softDeletes 即可,模型默认是没有开启软删除功能的开启也很简单就是使用SoftDeletes <?...Laravel数据库迁移 有创建这个字段的方法 现在,当你在模型实例上使用 delete 方法, 当前日期时间会写入 deleted_at 字段。...执行完毕后up来查询下数据库 ? id等于8数据被彻底删除啦 到现在增删改查 up 就都了解了

1.6K21

分享8Laravel模型时间戳使用技巧小结

默认情况下,Laravel Eloquent 模型默认数据表有 created_at 和 updated_at 两个字段。当然,我们可以做很多自定义配置,实现很多有趣的功能。下面举例说明。 1....禁用时间戳 如果数据表没有这两个字段,保存数据时 Model::create($arrayOfValues); —— 会看到 SQL error。...修改时间戳默认列表 假如当前使用的是非 Laravel 类型的数据库,也就是你的时间戳列的命名方式与此不同该怎么办? 也许,它们分别叫做 create_time 和 update_time。...并且 Laravel 不会尝试自动填充 created_at/updated_at 但是如果你想自动保存时间戳,您需要在迁移文件中添加 created_at/updated_at,然后在模型的关联中加上...post() { return $this- belongsTo('Post'); } } 8.

3.7K31
您找到你想要的搜索结果了吗?
是的
没有找到

Laravel 如何实现数据的软删除

对于任何一个模型,如果需要使用删除功能,需要在模型使用 Illuminate\Database\Eloquent\SoftDeletes这个 trait。...软删除功能需要实现的功能有以下几点: 1.模型执行删除操作,只标记删除,不执行真正的数据删除 2.查询的时候自动过滤已经标记为删除数据 3.可以设置是否查询已删除数据,可以设置只查询已删除数据 4...Laravel中软删除数据的过滤也是使用这种方式实现的。...,会根据throughParentSoftDeletes判断中间模型是否有软删除,如果有软删除会过滤掉中间模型删除数据。...但是有的时候,项目中会使用一个整形的字段标记数据是否删除。在这样的场景下,需要对Laravel的软删除进行修改才能够实现。

2.4K10

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

在上一篇教程中,我们基于 Eloquent 模型实现了对数据表记录的增删改查操作,今天我们在此基础上介绍两个 Eloquent 模型提供的高级功能 —— 批量赋值和软删除。...而对于相对稳定或者字段很多的数据表,建议使用黑名单,免去设置字段之苦,但是对于这样的模型类,每次修改数据表结构的时候都要记得维护这个黑名单,看看是否需要变动。...实现原理 Eloquent 模型类为我们提供了「软删除」功能的支持。这就意味着,在 Laravel 中,我们不需要编写任何额外代码就可以实现对数据库记录的「软删除」。...要软删除一条记录,在对应模型类实例上调用 delete 方法即可,底层会自动将数据表的 deleted_at 字段设置为当前时间,表示该记录已经被「删除」。...0)->restore(); // 恢复多条记录 最后,如果你确实是想物理删除数据表记录,通过 forceDelete 方法删除即可: $post->forceDelete(); 这样,模型实例对应数据表记录就会彻底灰飞烟灭

2.3K10

Laravel框架Eloquent ORM删除数据操作示例

本文实例讲述了Laravel框架Eloquent ORM删除数据操作。...分享给大家供大家参考,具体如下: 这篇文章,以下三个知识点希望大家能够掌握 如下: 通过模型删除 通过主键值删除 通过指定条件删除 NO.1模型删除 老样子,我们先新建一个方法,然后输入代码。...,受影响的删除数据总数为1,当然,如果要删除多条数据也很简单,代码如下: namespace App\Http\Controllers; use App\Student; use Illuminate\...,我就不手动演示了 更多关于Laravel相关内容感兴趣的读者可查看本站专题:《Laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程...》及《php常见数据库操作技巧汇总》 希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

51831

10个技巧优化PHP程序Laravel 5框架

文件删除。...可以使用下面命令清除路由缓存: php artisan route:clear 此命令做的事情就是把 bootstrap/cache/routes.php 文件删除。...数据库请求优化 数据关联模型读取时使用 延迟预加载 和 预加载 ; 使用 Laravel Debugbar 或者 Clockwork 留意每一个页面的总数据库请求数量; 这里的篇幅只写到与 Laravel...8. 为数据集书写缓存逻辑 合理的使用 Laravel 提供的缓存层操作,把从数据库里面拿出来的数据集合进行缓存,减少数据库的压力,运行在内存上的专业缓存软件对数据的读取也远远快于数据库。...() { return Post::with('comments', 'tags', 'author', 'seo')->whereHidden(0)->get(); }); remember 甚至连数据关联模型也都一并缓存了

5.3K20

Laravel系列4.3】模型Eloquent ORM的使用(一)

通过前两篇文章的铺垫,我们很容易就能操作 Laravel 中的模型,但是,真正要改变的是你看待这种操作数据库的方式。要把数据库里的数据想像成是编程语言中的对象,这才是 ORM 最主要的内容。...对于 Laravel 中标准的 Eloquent 模型类来说,每个表都应该有两个字段,一个是 updated_at ,另一个是 created_at ,分别是两个时间戳字段,用于记录数据的创建时间和修改时间...之所以要有外键这个东西,主要也是为了数据之前能够在数据库层面保持一定的关联,这样我们就可以做一些特殊的操作,比如说定义数据库的事件或者定时任务之类的,或者在关联删除的时候能够更加有效率。...db_sex 表的模型,这个表是上篇文章中测试时使用的,就直接拿来使用了。...下篇文章我们还将继续进行模型的学习以及整个模型的源码分析。 参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406

8.8K20

Laravel系列4.4】模型Eloquent ORM的使用(二)

模型Eloquent ORM的使用(二) 对于模型的探索我们还将继续。上篇文章中,只是简单地通过模型操作了一下数据库,并且学习了一下关联操作的知识。...比如说我们可以使用类似于 array_map() 的函数把集合中的对象全部转换成数组,还可以用一个类似于 array_column() 的函数只获取数据中的两个字段组成键值对形式的数据。...而另外一个 map() 函数就不用多说了,之前我们说过,Laravel 的 PDO 在默认查询构造器的情况下,走的是 PDO::FETCH_OBJ ,获得的集合结果中的每个数据都是一个 stdClass...这里路由的 mTest 参数实际上就是我们查询数据的主键 ID ,然后模型就会自动为我们查询相应的数据并注入到 $mTest 参数中。...参考文档: https://learnku.com/docs/laravel/8.x/eloquent/9406

2.8K20

laravel - 根据数据库逆向生成模型文件

写在最前 上一篇文件已经讲解了如何从数据库逆向生成迁移文件,那么对于懒癌晚期的我是万万不够的,所以说我又找到了一个可以逆向生成模型文件的库,经过测试,自定义功能非常的强大。...安装 安装过程稍微复杂一些,首先需要通过composer去安装库 composer require reliese/laravel --dev 然后使用artisan生成配置文件,在config/models.php...有非常多的细节都可以在这里面配置) php artisan vendor:publish --tag=reliese-models # 为了以防万一,刷新一下缓存 php artisan config:clear 使用...完成上面的安装工作,就能以一个非常优美的姿势,生成模型文件了 php artisan code:models 同时还支持下面几种方式使用 # 为指定数据表生成模型 php artisan code:models...--table=users # 为指定连接生成模型 php artisan code:models --connection=mysql 如果还需要自定义更多的内容,就需要去config/models.php

48810

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

引言 上一节我们讲了通过模型方法新建条目,或者更新数据。对于写操作还有更为重要的一个方法, 就是数据删除删除数据,有物理删除和软删除的区别。 ?...我们从软删除使用,再顺便说一说模型内的作用域的概念。 代码时间 常规的删除操作分两步进行,一步是把数据数据库中查询出来,使用laravel模型的方法, 则返回的是一个模型对象。...所以引入了软删除的概念,就是在表内添加一个字段,用于标记,这一行条目是否算是删除状态。在laravel中, 这个软删除字段默认是 deleted_at。你也可以在模型中手动指定。...然后在模型中,引入软删除的功能,将其进行全局生效的使用。...写在最后 本文从laravel模型的写操作删除动作,讲到了软删除的概念。进而引申出来本地作用域和全局作用域的使用。软删除几乎贯穿了我们应用的始终,需要大家勤学苦练。

1.3K30

【PHP 随记】—— laravel 目录结构分析

bootstrap |-- cache |-- app.php (3) \textbf{config 目录} :项目的配置目录,主要存放配置文件,比如项目总体配置、数据库的配置等。...{database 目录} :包含数据填充和迁移文件以及模型工厂类,还可以把它作为 SQLite 数据库存放目录。...(8) \textbf{storage 目录} :主要是存放缓存文件和日志文件,注意,如果在 linux 环境下,该目录需要有可写权限。(后期用户上传文件如果存在本地则也在 storage 下。...(10) \textbf{vendor 目录} :主要是存放第三方的类库文件;laravel 思想主要是共同的开发,不要重复的造轮子(例如,里面可能存在验证码类,上传类,邮件类),该目录还存放 laravel...(13) \textbf{composer.json 依赖包配置文件} :composer 需要使用,声明当前需要的软件依赖,不能删除

3.3K10
领券