dtwk6019 2018-04-06 03: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 12:45
    关注

    Try this:

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

报告相同问题?

悬赏问题

  • ¥20 Python安装cvxpy库出问题
  • ¥15 用前端向数据库插入数据,通过debug发现数据能走到后端,但是放行之后就会提示错误
  • ¥15 python天天向上类似问题,但没有清零
  • ¥30 3天&7天&&15天&销量如何统计同一行
  • ¥30 帮我写一段可以读取LD2450数据并计算距离的Arduino代码
  • ¥15 C#调用python代码(python带有库)
  • ¥15 矩阵加法的规则是两个矩阵中对应位置的数的绝对值进行加和
  • ¥15 活动选择题。最多可以参加几个项目?
  • ¥15 飞机曲面部件如机翼,壁板等具体的孔位模型
  • ¥15 vs2019中数据导出问题