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条)

报告相同问题?

悬赏问题

  • ¥15 如何让企业微信机器人实现消息汇总整合
  • ¥50 关于#ui#的问题:做yolov8的ui界面出现的问题
  • ¥15 如何用Python爬取各高校教师公开的教育和工作经历
  • ¥15 TLE9879QXA40 电机驱动
  • ¥20 对于工程问题的非线性数学模型进行线性化
  • ¥15 Mirare PLUS 进行密钥认证?(详解)
  • ¥15 物体双站RCS和其组成阵列后的双站RCS关系验证
  • ¥20 想用ollama做一个自己的AI数据库
  • ¥15 关于qualoth编辑及缝合服装领子的问题解决方案探寻
  • ¥15 请问怎么才能复现这样的图呀