微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

无效的运算子'$ addToSet'

如何解决无效的运算子'$ addToSet'

我有一个问题。当我尝试执行此查询时,查询给我此错误“无效的运算符'$ addToSet'”

        $qb = $this->createAggregationBuilder();
        $qb
            ->match()
            ->field('categories')->in($categories)
            ->field('hidden')->field('hidden')->notEqual(true)
            ->unwind('$type')
            ->unwind('$variants')
            ->unwind('$variants.subvariants')
            ->unwind('$variants.subvariants.params')
            ->group()
            ->field('id')->expression('$type')
            ->field('param')->addToSet(
                $qb
                    ->expr()
                    ->field('id')->expression('$variants.subvariants.params.param')
                    ->field('values')->addToSet('$variants.subvariants.params.value')
            );

        $res_params = $qb->execute()->toArray();

有人知道如何正确执行此查询吗?

我需要这样的结果

[
    {
        "_id": {
            "$ref": "Type","$id": "f564ece4fe4b4cdd9f1ccd8f092a98f9","$db": "skibike"
        },"param": [
            {
                "_id": {
                    "$ref": "Param","$id": "10f67225cfbe4c0e962828f32ea0fc25","$db": "skibike"
                },'values': [1,2,3]
            },{
                "_id": {
                    "$ref": "Param","$id": "5ee15b7cc9404ceab9eb41f48e8622f5",'values': [5,4]
            }
        ]
    }
]

谢谢

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。