MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

Não é possível usar VariableOperators.mapItemsOf aninhados no Spring Data MongoDb


Use $reduce com $concatArrays para juntar as matrizes.
 new ProjectionOperation().and(
    ArrayOperators.arrayOf("processes")
      .reduce(ArrayOperators.ConcatArrays.arrayOf("$$value").concat(
           VariableOperators.mapItemsOf("$$this.ownership.assignees")
               .as("ass")
               .andApply(aggregationOperationContext -> {
           Document document = new Document();
           document.append("id", "$$ass.id");
           document.append("value", "$$ass.username");
           document.append("parentObjectId", "$$this.id");
           return document;
          })
    )).startingWith(Arrays.asList())
).as("results");