【问题标题】:How to write this raw query using query builder? Is my one correct?如何使用查询生成器编写这个原始查询?我的对吗?
【发布时间】:2017-09-26 09:02:21
【问题描述】:

这是原始查询的预期结果

$sql = 'SELECT  c.*
FROM catalogs c
LEFT JOIN (SELECT s.* FROM stock s WHERE s.date = "'.$dateOption.'") as sb      
on sb.id_product = c.id_product
WHERE c.id_branch = '.Auth::user()->id_branch.';

$list = DB::select($sql);

我使用查询生成器对其进行了修改,但结果不正确

$lists = DB::table('catalogs')
            ->leftJoin('stock', 's.id_product','=','catalogs.id_product')
            ->where('s.date',$dateOption)
            ->where('catalogs.id_branch',Auth::user()->id_branch)
            ->get();

谁能告诉我应该如何在查询生成器中编写它?

【问题讨论】:

  • 有什么错误吗?你能告诉我们两个结果吗?哪个是正确的结果集?谢谢
  • 您的查询有什么问题?
  • 我只是想知道我在查询生成器中写的内容是否正确引用了原始查询。

标签: mysql laravel laravel-query-builder


【解决方案1】:

定义关系 (more details)

传递给 hasOne 方法的第一个参数是相关模型的名称。一旦定义了关系,我们就可以使用 Eloquent 的动态属性来检索相关记录。动态属性允许您访问关系方法,就好像它们是在模型上定义的属性一样:

命名空间应用程序;

use Illuminate\Database\Eloquent\Model;

class User extends Model
{
    /**
     * Get the phone record associated with the user.
     */
    public function phone()
    {
        return $this->hasOne('App\Phone');
    }
}

然后你可以像下面这样获得加入。

$phone = User::find(1)->phone;

【讨论】:

  • OP 想要在查询生成器中找到解决方案,而不是在 eloquent 中
  • 这样复用性更强,使用框架的目的是什么? :)
  • 我明白,但可能是 OP 对 eloquent 不太满意。这就是为什么:P
猜你喜欢
  • 1970-01-01
  • 2020-10-11
  • 2022-06-27
  • 2018-09-28
  • 1970-01-01
  • 2021-12-26
  • 2019-11-03
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多