在跳过和限制应用聚合构建器之前获取记录总数 symfony

问题描述

我在 TransactionRepository.PHP 中有以下查询

    //Query Builder
    $qb = $this->createqueryBuilder();

    //Aggregation Builder
    $builder  = $this->getDocumentManager()->createAggregationBuilder(Transaction::class);

    //pagination request from frontend
    $start = $filters['start'];
    $length = $filters['length'];

    //query conditions
    if ($filters['query']) {
        $r = new \MongoRegex('/'.$filters['query'].'/i');
        try {
            $builder -> match()
                        ->addAnd(
                            $qb->expr()
                                ->addOr($qb->expr()->field('id')->equals(new ObjectId($filters['query'])))
                        );
        }catch (\Exception $e) {
            $builder -> match()
                        ->addAnd(
                            $qb->expr()
                                ->addOr($qb->expr()->field('externalId')->equals($r))
                                ->addOr($qb->expr()->field('buyerIdentifier')->equals($r))
                                ->addOr($qb->expr()->field('paddedCardNumber')->equals($r))
                                ->addOr($qb->expr()->field('buyerIdentifier')->equals($r))
                                ->addOr($qb->expr()->field('providerBrandName')->equals($r))
                                ->addOr($qb->expr()->field('securityWord')->equals($r))
                        );
        }
    }

    if ($filters['merchants']) {
        array_walk($filters['merchants'],function (&$i) {
            $i = new \MongoId($i);
        });
        $builder -> match()
                    -> addAnd(
                        $qb->expr()->addAnd($qb->expr()->field('merchantId')->in($filters['merchants']))
                    );
    }


      $builder
        ->lookup('companies')
        ->localField('merchantId')
        ->foreignField('_id')
        ->alias('merchant')

        //flatten the result
        ->unwind('$merchant');

    if ($filters['hydrate']) {
        $builder -> hydrate(Transaction::class);
    } else {
        $builder ->project()
            ->includeFields([
                'id','merchant._id','merchant.TradingName','state','provider','amount','created','currency','history'
            ]);
    }

    $builder ->sort(['created' => 'DESC']);

    if (!is_null($start) && !is_null($length)) {
        $builder    ->skip($start)
                    ->limit($length);
    }

    return $builder ->execute(["allowdiskUse" =>true])->toArray();

我想在 skip()limit() 应用之前有一个总数。 假设 $start =0$length = 10,我的 MongoDB 中总共有 100 条记录,我想在 limit 应用之前将总记录数绑定。我怎样才能做到这一点?我知道我必须使用 facet() 但我不知道如何在aggregationBuilder 中实现它。提前致谢

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)