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

Jan*_*ara 5 php mysql silex eloquent

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

Group.php(型号)

 public function users()
    {
        return $this->belongsToMany('\Modules\User\Models\User');
    }
Run Code Online (Sandbox Code Playgroud)

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'];
}
Run Code Online (Sandbox Code Playgroud)

但这不起作用.

Jan*_*ara 3

我发现了。

服务.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."
    ];
}
Run Code Online (Sandbox Code Playgroud)

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

  • 你也可以这样做。$结果 = $组->用户->count(); if ($result>0) { return $this->response(true, $errMsg . '群组有用户'); }else { $group->delete($data['groupID']); return $this->response(false, '群组删除成功'); }' (2认同)