使用查询作用域后 子查询无法合并绑定(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();
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
讨论数量: 1

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