Google App Engine Objectify получает внука сущности

У меня есть такие объекты: User->Blague->Score, где у пользователя есть множество blagues (дочерних элементов), а у blague есть один балл.

Я пытаюсь получить счет от blague, но когда я пишу это:

User userPoster = ofy().load().type(User.class).id(5066549580791808L).now();
Blague blague = ofy().load().type(Blague.class).parent(userPoster).id(4609152743636992L).now();
Score score = ofy().load().type(Score.class).parent(blague).id(5735052650479616L).now();
resp.getWriter().println(userPoster);
resp.getWriter().println(blague);
resp.getWriter().println(score);

(Идентификаторы правильные) оценка равна нулю, в отличие от blague и userPoster. Почему он нулевой?

Сущности создаются так:

@ApiMethod(
        name = "addBlague",
        path = "addBlague",
        httpMethod = ApiMethod.HttpMethod.POST)
public void addBlague(
        @Named("category") EnumCategory category,
        @Named("type") EnumType type,
        @Named("lenght") EnumLenght lenght,
        @Named("keywords") List<String> keywords,
        @Named("text") String text,
        @Named("userId") Long userId){
    Key<User> userKey = Key.create(User.class, userId);
    Blague blague = new Blague(category, type, lenght, text, userKey);
    ofy().save().entity(blague).now();
    Key<Blague> blagueKey = Key.create(Blague.class, blague.getId());
    Score score = new Score(0, 0, blagueKey);
    ofy().save().entity(score).now();
    for (String word : keywords) {
        KeyWord keyword = new KeyWord(word, blagueKey);
        ofy().save().entity(keyword);
    }
}

и, конечно же, классы регистрируются.

Как я могу получить счет от blague ?

Спасибо

Редактировать. Код Socre:

package blagueur;

import java.util.HashMap;

import com.googlecode.objectify.Key;
import com.googlecode.objectify.annotation.Cache;
import com.googlecode.objectify.annotation.Entity;
import com.googlecode.objectify.annotation.Id;
import com.googlecode.objectify.annotation.Index;
import com.googlecode.objectify.annotation.Parent;


@Entity
@Index
@Cache
public class Score {
    @Id
    private Long id;
    private int likes;
    private int dislikes;
    private HashMap<String, Boolean> voters;
    @Parent
    private Key<Blague> blagueKey;

    private Score() {}

    public Score(int likes, int dislikes, Key<Blague> blague) {
        this.likes = likes;
        this.dislikes = dislikes;
        this.blagueKey = blague;
        this.voters = new HashMap<String, Boolean>();
    }

    public Long getId() {
        return id;
    }

    public int getLikes() {
        return likes;
    }

    public int getDislikes() {
        return dislikes;
    }

    public void addVote(Long userId, boolean like){
        voters.put(String.valueOf(userId), like);
        if (like){
            likes++;
        }
        else{
            dislikes++;
        }
    }

    public void removeVote(Long userId){
        String id = String.valueOf(userId);
        boolean like = voters.get(String.valueOf(userId));
        voters.remove(String.valueOf(userId));
        if (like){
            likes--;
        }
        else{
            dislikes--;
        }
    }

    public Key<Blague> getBlagueKey() {
        return blagueKey;
    }
}

person Skartt    schedule 14.12.2014    source источник
comment
У вас есть @Parent в черном ключе в определении типа Score? Может быть, покажите нам код Score.   -  person tomrozb    schedule 15.12.2014
comment
Да, я добавил в ответ правку, чтобы показать код socre.   -  person Skartt    schedule 15.12.2014


Ответы (1)


Вы должны быть очень осторожны, чтобы поддерживать иерархию ключей.

Вы заявляете, что ваша предполагаемая иерархия сущностей — это User -> Blague -> Score, но этот код ниже этого не делает:

Key<User> userKey = Key.create(User.class, userId);
Blague blague = new Blague(category, type, lenght, text, userKey);
ofy().save().entity(blague).now();
Key<Blague> blagueKey = Key.create(Blague.class, blague.getId());
Score score = new Score(0, 0, blagueKey);
ofy().save().entity(score).now();

Когда вы создаете blagueKey, вы не используете userKey в качестве родителя. Хотя я не одобряю написанный вами стиль кода, если вы хотите это сделать, вам нужно сделать следующее:

...
Key<Blague> blagueKey = Key.create(userKey, Blague.class, blague.getId());
...

В общем, вы должны позволить объектизации сделать это за вас, используя Ref<User>, Ref<Blague> в качестве объектов @Parent, или, если вам необходимо создать объекты Key, используйте Key.create(T pojo), а не управляйте ключами самостоятельно.

person Nick    schedule 15.12.2014