I want to create spring boot repository query using mongo db. I have collection name as qualification
{
"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"
}
I tried the below query to get whatever matches this pattern ja,
db.employee.aggregate([{$match:{"code" : "DEVELOPER"}},
{$project : {listItems:{$filter:{
input: "$listItems",
as: "listItems",
cond: { $regexMatch:{
input:"$$listItems.item",
regex: /ja/i} }
}}}}])
and i got exact answer as,
{
"code": "DEVELOPER",
"description": "Software Developer",
"status": "ACTIVE",
"listItems": [
{
"itemId": "JAVA",
"item": "Java"
},
{
"itemId": "JAVASCRIPT",
"item": "Javascript"
}
],
"returncode": "00000",
"message": "Data Available"
}
But when i tried in java using mongotemplate and got NULL pointer exception and didn't get any output
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);
}