php - 如何从 Eloquent ,silex的中间表中获取数据

标签 php mysql eloquent silex

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

Group.php(模型)

 public function users()
    {
        return $this->belongsToMany('\Modules\User\Models\User');
    }

服务.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'];
}

但这行不通。

最佳答案

我发现了。

服务.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."
    ];
}

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

关于php - 如何从 Eloquent ,silex的中间表中获取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34959601/

相关文章:

javascript - 为什么我的 JS slider (Slick) 会干扰我的联系表单上的 PHP 验证?

php - Mysql查询语句索引调优

php - 无法使用 php session 重定向到另一个页面

mysql - 如何使用 Eloquent 获取 N 个最新的数据库条目?

php - Laravel 动态创建多个数据库的方法

php - Laravel 变形关系

xml - 解析器错误 : String not started expecting ' or " in php

php - 合并日期和时间后显示 PHP fatal error

php - 从您的数据库订购信息

mysql - 查询难度更大的多对多关系