https://github.com/mongodb/mongo-java-driver
Ты имеешь в виду raw запрос, тупо как есть закинуть монге? Походу так и придется сделать.) Но все же опишу проблему: Сейчас делаю один запрос findAll с фильтрацией и пагинацией (пагинация бог с ней skip limit в агрегейшн) Структура такая (лишнее не писал): User: _id Set<Role> (Set<ObjectId> - мануал референс) Set<Right> Role: _id Set<Right> То есть у юзера есть права, плюс список ролей, у каждой роли еще список прав (то есть права можно добавлять с ролями, а можно и без ролей) Нужно отфильтровать по списку прав findAll(Set<Right> filterList) Свел к этому: db.collection.aggregate([{"$lookup":{"from":"role","localField":"roles","foreignField":"_id","as":"rls"}},{"$addFields": { finalRoles: { $setUnion: [ { $reduce: { input: "$rls.rights", initialValue: [ ], in:{$concatArrays: ["$$value","$$this"]}} },"$right"]} }}, {"$match": { "finalRoles": {"$in": ["ADMIN","asdf"]}}}]) Лукапом достал по айдишникам, потом добавил поле куда смержил права от ролей, редьюсом собранные в кучу, и юнион с rights которые в юзере отдельно от ролей ну и в конце match Вроде работает. Но меня смущает, что я добавляю филд только чтобы по нему отфильтровать, да бог с ним .... Сейчас у меня не получается даже { $reduce: { input: "$rls.rights", initialValue: [ ], in:{$concatArrays: ["$$value","$$this"]}} } сделать с помощью mongoOperation/mongoTemplate (для каждого юзера из листа ролей достать листы прав и засунуть в 1 лист прав)
Обсуждают сегодня