سؤال

لدي طاولات:

users {id, name}
projects {id, name}
roles {id, name}
projects_users {id, user_id, project_id, role_id}

لدي نماذج:

project { has many users through projects_users }
user { has many projects through projects_users }

سؤال: كيف أحصل على أدوار المستخدم لمشروع واحد؟ أو ربما لا بد لي من إعادة بناء طاولاتي؟

شفرة:

$project = ORM::factory('project', $id);
$users = $project->users->find_all();
foreach ($users as $u) {
    $roles = $u-> .... How to get all roles for this user and for this project?
}
هل كانت مفيدة؟

المحلول

يبدو أن جدول Project_users الخاص بك يمثل أدوارًا في المشاريع ، إضافة نموذج آخر مرتبط بهذا الجدول:

project_role { 
    has one user 
    has one role
    has one project
}
user {
    has many project_role
    ...
}
project {
    has many project_role
    ...
}

ثم قد تكون قادرًا على القيام:

$user = ORM::factory('user')
    ->with('project_role')
    ->where('project_role.project_id', '=', $id)
    ->with('project_role:role')->findall();

إذا لم ينجح ذلك ، فيجب أن ينجح أحد ما يلي ، ولكن قد يكون شكلًا مختلفًا من أشكال اجتياز ما تتبعه.

$project = ORM::factory('project', $id);
$roles = $project->project_role->with('user')->with('role')->findall();

أو

$roles = ORM::factory('project_role')
    ->where('project_id', '=', $id)
    ->with('user')->with('role')->findall();
مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top