加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

php – 如何从eloquent,silex中的中间表中获取数据

发布时间:2020-12-11 23:51:20 所属栏目:MySql教程 来源:网络整理
导读:我创建了数据库表users,groups和group_user(MySQL).而group_user表(中间表)包含user_id和role_id.用户和群体的关系是多对多的.我想删除组表中的组.在删除组之前,我想检查是否有任何用户属于该组. 我试着这样做. Group.php(型号) public function users() { r

我创建了数据库表users,groups和group_user(MySQL).而group_user表(中间表)包含user_id和role_id.用户和群体的关系是多对多的.我想删除组表中的组.在删除组之前,我想检查是否有任何用户属于该组.
我试着这样做.

Group.php(型号)

 public function users()
    {
        return $this->belongsToMany('ModulesUserModelsUser');
    }

Service.php

public function deleteGroup($data) {
    if (!isset($data['groupID']))
        return ['error' => 'Failed to delete group. Group id is required'];

    $group = Group::find($data['groupID']);
    if (!$group)
        return ['error' => 'Failed to delete group. Group not found'];

    // check any user belongs to group. 
    $result = $group->users()->pivot->user_id;

    if(!$result){
       $group->delete();
       return ['success' => 'Successfully delete group.'];
    }
    return ['error' => 'Failed to delete group. Group not found'];
}

但这不起作用. 最佳答案 我发现了.

service.php

public function deleteGroup($data) {

    $group = Group::find($data['groupID']);
    if (!$group){
        return [
            "msg" => "Failed to delete group. Group not found."
        ];
    }
    // find out any one belongs to the group.           
    $result = $group->users->first()->userID;
    if ($result){
        return [
            "msg" => "Failed to delete group. Group has users."
        ];
    }

    $result = $group->delete($data['groupID']);
    if(!$result){
        return [
            "msg" => "Failed to delete group."
        ];
    }

    return [
        "msg" => "Successfully deleted group."
    ];
}

我就是这样做的.如果还有其他方式请告诉我.谢谢.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读