模型关联,可以设置是join形式吗

public function order_goods(): HasOne
{
  return $this->hasOne(Model::class, 'lists_id')->setBindings();
}
with(['order_goods']=>function($query){
    $query->where('id',1);
})

如果这样的使用查询出来的是order_goods=>null,但是我需要的是整个sql为空,是否可以像tp一样指定一个关联方式joinType=join的方式呢?

《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
讨论数量: 12

你要的应该是这个?模型关联《Laravel 9 中文文档》

1年前 评论
charming-xiaoxia (楼主) 1年前

你的意思是 order_goods=>null等于null的情况下这条数据都不查询出来?
with(“order_goods”)->whereHas(“order_goods”,function($query){
$query->where(“id”,1);
})

1年前 评论
charming-xiaoxia (楼主) 1年前
Weiwen 1年前
charming-xiaoxia (楼主) 1年前
Weiwen 1年前
Order::with(“order_goods”)->whereHas(“order_goods”,function($query){
$query->where(“id”,1);
})->get();
1年前 评论
charming-xiaoxia (楼主) 1年前

区分左右表的大小,再决定使用where exists还是where in或者自己实现join

1年前 评论

laravel的底层都是英文版,英文阅读能力太差了,在tp的底层是有一个方法

  /**
     * 设置join类型
     * @access public
     * @param  string $type JOIN类型
     * @return $this
     */
    public function joinType(string $type)
    {
        $this->joinType = $type;
        return $this;
    }

拉瓦的底层我找了一会没发现好像

1年前 评论

这俩个包,一个提供了 join ,一个听了 where...in 的方式。

1年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!