使用查询作用域后 子查询无法合并绑定(mergeBindings)

    public function apply(Builder $builder, Model $model)
    {
        $builder->where(DB::raw('LEFT(sampleno,1)'), '<>', 'T')->whereIn('sjsdm',['018','019']);
    }

后面的

$sub = $model->whereRaw('yp_lx is not null')->select('yp_lx','styleno')->groupBy('yp_lx','styleno');
$count = DB::table( DB::raw("({$sub->toSql()}) as sub") )
->mergeBindings($sub->getQuery())
->count();

生成sql 里面的参数依旧被 "?" 代替

解决办法

$sub = $model->withoutGlobalScope(AgeScope::class)->where(DB::raw('LEFT(sampleno,1)'), '<>', 'T')->whereIn('sjsdm',['018','019'])->whereRaw('yp_lx is not null')->select('yp_lx','styleno')->groupBy('yp_lx','styleno');
$count = DB::table( DB::raw("({$sub->toSql()}) as sub") )
->mergeBindings($sub->getQuery())
->count();
《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
讨论数量: 1

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