dtwk6019 2018-04-05 19:58
浏览 174
已采纳

Laravel - 如何在相关表和父表中同时添加where语句?

I have two tables: members (userdata, email, etc) and users (username, password, etc). All users are members but not all members are users. I defined the relationship in laravel:

Member.php

public function user() {
    return $this->hasOne('App\Models\User');
}

Now I want to be able to retrieve a member's data either by email or by username (if it exists) without using join(). Basically:

where('email','=','blah123')->orWhere('username','=','blah123')

I want the relationships returned in their own arrays like:

{
    firstname: blah,
    email: blah@blah.com,
    user: [
        username: blah123
    ]
}

And when I use join() it returns a flat array which is not ideal:

{
    firstname: blah,
    email: blah@blah.com,
    username: blah123
}

How would I go about it?

  • 写回答

2条回答 默认 最新

  • dsaaqdz6223 2018-04-06 04:45
    关注

    Try this:

    where('email','=','blah123')->orWhereHas('user', function($query) { 
        $query->where('username','=','blah123');
    })->with('user')
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部