سؤال علاقات Kohana orm
-
25-09-2019 - |
سؤال
لدي طاولات:
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();
لا تنتمي إلى StackOverflow