`hasone` 关联为什么生成 `is not null` 的 SQL 语句

    /**
     * 关联订单
     *
     */
    public function order()
    {
        return $this->hasOne(Order::class,'order_uuid', 'order_uuid');
    }
select
  *
from
  `orders`
where
  `orders`.`order_uuid` = '3321718356437'
  and `orders`.`order_uuid` is not null
  and `orders`.`delete_time` is null
limit
  1

这样做有什么意义

我未曾珍惜的,我不再拥有?‍?️
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 5

我的 hasOne 也不会加 is not null 所以我猜想这不是 hasOne 的问题,您可以检查下是否有别的代码影响

3年前 评论

uuid 不为 null 给你筛选了,delete_time 应该是软删除,为空则是没删除的??

3年前 评论
DogLoML

用了软删除

3年前 评论

找到原因了,文件地址:

vendor/laravel/framework/src/Illuminate/Database/Eloquent/Relations/HasOneOrMany.php

67 行:

public function addConstraints()
    {
        if (static::$constraints) {
            $this->query->where($this->foreignKey, '=', $this->getParentKey());

            $this->query->whereNotNull($this->foreignKey);
        }
    }
3年前 评论