2010-08-03 111 views
4

我有表:Kohana的ORM的關係問題

 
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? 
} 
+0

雖然我是新手我自己,這種方法可能適用於您的情況:http://stackoverflow.com/questions/3286539/kohana-3-orm-how-to -perform查詢與 - 2 - 多到多對多關係 – 2010-10-18 06:39:20

回答

1

你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(); 

如果這樣不起作用,下列其中一項應該可行,但可能是不同的形式o f遍歷你所追求的東西。

$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();