Mysql 连接多个表并获取条件数据的Laravel DB查询

Mysql 连接多个表并获取条件数据的Laravel DB查询,mysql,join,laravel-5,laravel-5.3,union,Mysql,Join,Laravel 5,Laravel 5.3,Union,我有以下要查询数据的表列表 users id email 1 user1@test.com 2 user2@test.com user_projects project_id user_id role 1 1 member 1 2 owner projects id name 1 example project 我希望结果数据如下所示 project_id na

我有以下要查询数据的表列表

users 
id email   
1 user1@test.com
2 user2@test.com          

user_projects 
project_id user_id role               
1           1       member
1           2       owner

projects 
id name 
1  example project
我希望结果数据如下所示

project_id name              email             role    owner
1          example project   user1@test.com    member  user2@test.com
简而言之,我想获取用户所参与的项目列表,以及他的角色和项目所有者

我提出了以下问题

return DB::table('user_projects')
        ->join('projects', 'user_projects.project_id', '=', 'projects.id')
        ->join('users', 'user_projects.user_id', '=', 'users.id')
        ->where('user_projects.user_id', '=', $userId)
        ->select('users.email', 'projects.id', 'users.id as user_id','user_projects.role as userRole',
            'projects.name')
        ->get()->toArray();

我能够获得项目列表和用户在项目中的角色,但无法找到项目的电子邮件所有者。

我认为这就是您需要的

select projects.id, projects.name, users.email, up1.email as owner, up2.role role from 
projects, (select * from user_projects, users where role='owner' and users.id=user_projects.user_id) up1, user_projects up2, users 
where 
projects.id=up1.project_id and 
up1.project_id = up2.project_id and 
up2.user_id=users.id  and users.id=1

我想这就是你需要的

select projects.id, projects.name, users.email, up1.email as owner, up2.role role from 
projects, (select * from user_projects, users where role='owner' and users.id=user_projects.user_id) up1, user_projects up2, users 
where 
projects.id=up1.project_id and 
up1.project_id = up2.project_id and 
up2.user_id=users.id  and users.id=1

请您进一步解释-电子邮件所有者是什么意思?请使用select('users.*)并显示其输出。请您进一步解释-电子邮件所有者是什么意思?请使用select('users.*)并显示其输出