首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >删除记录前检查Laravel 8中是否存在hasMany关系

删除记录前检查Laravel 8中是否存在hasMany关系
EN

Stack Overflow用户
提问于 2021-02-19 05:53:19
回答 1查看 600关注 0票数 0

我试图在删除之前检查是否存在一种关系。我在网上见过很多关于这方面的帖子,但似乎无法让它发挥作用--当我点击delete时,它忽略了我的@if语句,并删除了记录。

Models/Workorder.php

代码语言:javascript
复制
...
public function continuations()
    {
        return $this->hasMany(Continuation::class);
    }
...

Models/Continuation.php

代码语言:javascript
复制
...
public function workorder()
    {
        return $this->belongsTo(Workorder::class, 'workorder_id');
    }
...

workorders/index.blade.php

代码语言:javascript
复制
...
  <td class="pr-6">
        <a wire:click="deleteWorkorder({{$workorder->id}})"
           role="menuitem">
        </a>
  </td>
...

Workorders/Index.php

代码语言:javascript
复制
...
public function deleteWorkorder($id)
    {
        $record = Workorder::find($id);
        $conExists = Continuation::where('workorder_id', $record->id)->exists();

        if($conExists){
            session()->flash('failed-message', 'You can\'t delete a workorder that has a Continuation');
            return;
        }
        $record->delete();
        session()->flash('success-message', 'Workorder Deleted Successfully');

    }
...
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-19 05:59:41

通过使用isNotEmpty()来尝试类似的方法

代码语言:javascript
复制
$workorder= workorder::find($request->id);
            if ($workorder->continuations->isNotEmpty()) {
                return session()->flash('failed-message', 'You can\'t delete a workorder that has a Continuation');
            }
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66272404

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档