Исключение группы Mongotemplate

Я получаю NullPointerException при выполнении групповой операции шаблона mongo.

Код выглядит следующим образом:

GroupByResults<Recommendation> recommendations 
    = mongoTemplate.group("recommendation",
          GroupBy.key("doctor"), 
          Recommendation.class
);

POJO это:

package med.rec.model;

@Document
public class Recommendation extends BaseModel {
    public Recommendation(){

    }


    @Indexed
    @DBRef  
    private Doctor doctor;
    @Indexed
    private String specialty;
    private String x;  
    private int y;
    private int z;
    private int w;
    private String f;
    /*All getter and setters */ 
}

Трассировка стека кажется совсем неинформативной, но вот она:

ava.lang.NullPointerException
org.springframework.data.mongodb.core.MongoTemplate.group(MongoTemplate.java:1225)
org.springframework.data.mongodb.core.MongoTemplate.group(MongoTemplate.java:1199)
med.rec.controller.api.v1.RecommendationController.all(RecommendationController.java:43)
sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
java.lang.reflect.Method.invoke(Method.java:601)
org.springframework.web.method.support.InvocableHandlerMethod.invoke(InvocableHandlerMethod.java:215)
org.springframework.web.method.support.InvocableHandlerMethod.invokeForRequest(InvocableHandlerMethod.java:132)
org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:104)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandleMethod(RequestMappingHandlerAdapter.java:749)
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:690)
org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:83)
org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:945)
org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:876)
org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:961)

Пожалуйста, порекомендуйте.

Спасибо, Рой.


person James Zalame    schedule 15.03.2014    source источник
comment
Пожалуйста, добавьте трассировку стека   -  person Martin Baumgartner    schedule 16.03.2014


Ответы (1)


Ваше использование неверно, и по нескольким причинам. Сначала возьмите этот «пример» из документация:

GroupByResults<XObject> results = 
    mongoTemplate.group("group_test_collection", 
        GroupBy.key("x")
        .initialDocument("{ count: 0 }")
        .reduceFunction("function(doc, prev) { prev.count += 1 }"), 
    XObject.class);

И это класс result:

public class XObject {

    private float x;

    private float count;


    public float getX() {
        return x;
    }

    public void setX(float x) {
        this.x = x;
    }

    public float getCount() {
        return count;
    }

    public void setCount(float count) {
        this.count = count;
    }

    @Override
    public String toString() {
        return "XObject [x=" + x + " count = " + count + "]";
    }
}

Итак, первое, что вы делаете неправильно, это то, что у вас нет достаточных аргументов, указанных для построителя GroupBy. Этот метод является своего рода «оболочкой» для операций mapReduce, и поэтому нуждается в аналогичном стиле операций, переданных ему, чтобы работать.

Во-вторых, как показано в примере, класс, который вы передаете в качестве последнего аргумента, предназначен для результата, а не для класса "хранилище", как вы, кажется, делаете. Итак, что было бы необходимо, так это то, что соответствует структуре результатов, выдаваемых в результате операции, которые не будут такими же, как класс «хранилище».

В-третьих, вы, кажется, пытаетесь «сгруппировать» поле, которое является DBRef, и поэтому вы, скорее всего, не получите ожидаемых результатов. Можно посоветовать немного почитать на эту тему, так как предполагаемая функция DBRef может быть не тем, что вы хотите, и документация покрывает это.

Похоже, вам нужен aggregate, который также рассматривается в весенней справочной документации после слова «группа» в первой ссылке выше. Но в любом случае вам также нужно будет структурировать правильные аргументы для этого.

person Neil Lunn    schedule 16.03.2014