170 похожих чатов

Почему просто не возьмешь драйвер и не сделаешь с ним?

https://github.com/mongodb/mongo-java-driver

1 ответов

9 просмотров

Ты имеешь в виду 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 лист прав)

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Ты просто гитлеровскую эстетику плохо понимаешь. Он же всё под Цезаря делал. А это как бы запрещённый приём в политике. Пиджаки они зачем все носят? Чтобы показать что они тип...
Ivan Kropotkin
4
Привет, имею проблему с better-sqlite3 модулем. После npm install я делаю ребилд модуля под свою текущую версию ноды с помощью npx electron-rebuild -f -m node_modules/better-s...
Anton Samofal
1
а чем лучше всего сделать глобальный лок, если много нодов, до сотни? ну то есть мне надо, чтобы некоторые операции с объектом не происходили одновременно. перемещение между н...
Д. П.
15
Я вот так сделал, без base. Шаблон text называется, его контроллер: <?php namespace EvolutionCMS\Main\Controllers; use EvolutionCMS\TemplateController; class TextTemplateCo...
Oleg Nosov
1
А как лучше конвертировать физический адрес в виртуальный при маппинге? В случае ядра у меня, например, direct mapping, первые 768МБ я как есть мапплю в higher half, а остальн...
Evg Resh
26
Hi guys, I'm looking for a good LLM course. Is there any course to learn LLMs in advanced? I'm aiming to use them in my apps, so a perfect course in my openion, is not only a ...
Taha
14
База данных не поможет. Шифрование не поможет. Какие там ещё варианты? Накидывайте.
КТ315
20
Карта сайта