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

Laravel 软删除存在的问题

,如果类常量DELETED_AT为null,则不执行相应的软删除操作 4、join操作,只会在对当前模型添加软删除查询条件 5、在belonsToMany关联关系中,如果关联表,中间表,被关联表都有软删除字段...被关联表是一个类对象,如果应用了软删除,则会自动附加上软删除条件 6、在hasManyThrough关联关系中,如果关联表,中间表,被关联表都有软删除字段,查询关联关系,会对中间表应用删除条件。...但是,如果要查询包含已删除的关联关系,中间表的删除标记条件不会去除。 hasManyThrough中,中间表是通过中间对象传入,可以获取到中间表是否应用软删除。...但是中间表的软删除不是通过scope实现的,关联关系对象在创建的时候就已经把中间表的软删除条件附加上去了,因此,即使指定了withTrashed,也会有中间表的软删除查询条件。...从上面可以看出,Laravel的软删除,在关联关系中会造成一些查询上条件的歧义,非常容易产生bug.而且,belongsToMany中间表的问题是无解的。

2.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    SPA PP COGI中禁用删除按钮?

    点击左边可以跳转哦,本次讲下COGI如何进行删除按钮禁用,阿龙在老东家的时候曾经遇到关键用户不及时处理,删了7000条COGI记录 ?...通常,为了保证数据的一致性,这些错误的货物移动需要及时处理;不过,COGI中存在“删除”标识可将错误记录进行删除,表示这些数据确认核实无需处理; 该“删除”按钮按正规流程来说,由财务成本会计人员确认是否可删除较为合理...;生产业务人员可能因操作失误,将数据删除错误;因此对于生产业务人员其COGI权限中应当无“删除”标识; 系统标准情况 SAP标准COGI的删除标识存储在2个地方: 一是存储在汇总屏幕菜单栏中; ?...系统操作方案 采用SHD0变式将“删除”标识进行隐藏 1.创建事物代码变式 1.1.输入事物代码COGI,事物代码变式Z_COGI_VARIANT,并点击“创建”按钮; ? ? ? ? ? ?...其实SHD0也有bug,删除按钮虽然是没有了,但是右键还有 ? ? 如果有更好的方式,互相交流哈。

    1.7K20

    laravel 模型Eloquent ORM 添加编辑删除

    接下来 up 来学下模型的删除。 删除数据是一件很危险的行为,up 刚刚入行的时候不小心给生产环境的用户表删除了,当时全靠谷歌用的好给恢复了不然我就跑路了?,现实版删库跑路?。...当时我希望能有一个恢复删除的功能比如说回收站,laravel 的模型为我们提供了很方便的软删除功能 要启用软删除首先数据表需要有 deleted_at 字段 之前玩迁移的时候简单的说了下创建迁移的时候调用...Laravel 的 数据库迁移 有创建这个字段的方法 现在,当你在模型实例上使用 delete 方法, 当前日期时间会写入 deleted_at 字段。...现在刚刚软删除的数据又回来了,如果up只想查询乱删除的数据呢?...之前乱删除的数据变恢复回来了 但是如果要彻底删除改怎么做呢?

    1.7K21

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

    每次这么做得崩溃掉,到时候我们的控制器类里面可能会遍布这种设置代码,Laravel 号称的优雅就是打脸了。所以这个时候,批量赋值就粉墨登场了,批量赋值就是为我们解决这个问题的。...注:所谓物理删除就是彻底删除该记录,逻辑删除只是给这条记录打上一个「已删除」的标记,不再出现在查询结果中,但是并没有真正删除这条记录。...逻辑删除删除好处多多,既保证了不出现在查询结果中的实际需求,又满足了统计或查看历史数据的隐形需求。通常,我们也把逻辑删除称作「软删除」,那对应的物理删除就可以称作「硬删除」了。...实现原理 Eloquent 模型类为我们提供了「软删除」功能的支持。这就意味着,在 Laravel 中,我们不需要编写任何额外代码就可以实现对数据库记录的「软删除」。...本系列教程首发在Laravel学院(laravelacademy.org)

    2.5K10

    3分钟短文:Laravel 检查记录是否被软删除

    引言 laravel模型中引入了SoftDeletes这个全局作用域用于将数据库的条目 标记为删除,而实际上并不清除数据,这样可以为后续的数据恢复做铺垫。...{ use SoftDeletes; } 如果数据库表中正好是使用 deleted_at 标记删除日期时间,那么无需手动指定该字段为软删除字段了。...,和自定义软删除字段的方法。...使用了软删除功能后,会在模型的查询方法上,默认追加 where deleted_at is null 那么如果使用了全量查询后,如何判断一个记录是否是已经软删除的呢?laravel提供了这些功能。...写在最后 本文通过对laravel模型中软删除的源码分析, 为大家展示了引入软删除功能,并自定义软删除标记字段的方法。通过模型提供的方法,进而判断记录是否已软删除。

    1.5K30

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

    所以,软删除的概念,极为重要。 本文我们仍然不厌其烦地讲解软删除的功能。 物理删除 其实就是真实地把数据从数据库条目清除,laravel模型提供了开箱即用的方法。...真实的SQL如下: DELETE FROM events WHERE id = 12; laravel提供了许多语法糖,上面使用 find 和 delete 两个步骤,可以缩减为一个方法 destroy...Laravel本身支持软删除,只需要进行少量的配置更改,以确保在执行delete或destroy时,模型的记录不会被实际删除。作为一个例子,我们修改Event模型以支持软删除。...其实原理很简单,就是为模型追加一个全局作用域,为每个查询子句追加上如下筛选条件: WHERE deleted_at IS NULL laravel已经为我们写好这部分逻辑了,在模型内引入如下trait:...如果你在代码内要坚持查询全量数据,也包含软删除了的数据,那么代码这样写: $events = Event::withTrashed()->get(); 写在最后 本文我们有重温了laravel的模型软删除功能

    2.2K00
    领券