Как создать запрос репозитория весенней загрузки для запроса агрегирования? - PullRequest
0 голосов
/ 09 мая 2020

Я хочу создать запрос репозитория весенней загрузки, используя mon go db. У меня есть имя коллекции квалификация

{
    "code": "DEVELOPER",
    "description": "Software Developer",
    "status": "ACTIVE",
    "listItems": [
        {
            "itemId": "JAVA",
            "item": "Java"
        },
        {
            "itemId": "PYTHON",
            "item": "Python"
        },
        {
            "itemId": "PHP",
            "item": "Php"
        },
        {
            "itemId": "JAVASCRIPT",
            "item": "Javascript"
        }
    ],
    "returncode": "00000",
    "message": "Data Available"
}

Я попробовал запрос ниже, чтобы получить все, что соответствует этому шаблону ja ,

db.employee.aggregate([{$match:{"code" : "DEVELOPER"}},
{$project : {listItems:{$filter:{
    input: "$listItems",
               as: "listItems",
               cond: { $regexMatch:{
                        input:"$$listItems.item",
                        regex: /ja/i}  }
}}}}])

и Я получил точный ответ, как,

{
    "code": "DEVELOPER",
    "description": "Software Developer",
    "status": "ACTIVE",
    "listItems": [
        {
            "itemId": "JAVA",
            "item": "Java"
        },
        {
            "itemId": "JAVASCRIPT",
            "item": "Javascript"
        }
    ],
    "returncode": "00000",
    "message": "Data Available"
}

Но когда я попробовал java с использованием mongotemplate и получил исключение указателя NULL и не получил никакого вывода

public List<ListValue> findAllByCode(String code,String item) {
           Query query = new Query();
           query.addCriteria(Criteria.where("code").is(code).and("listItems.item").regex("^" + item + "$", "i"));

           return mongoTemplate.find(query, ListValue.class);
        }
...