我创建了数据库表 users
、groups
和 group_user
(MySQL)。还有 group_user
表(中间表)包含 user_id
和 role_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/