1

期望两个实体MovieGenre

@Entity
public class Movie {

@Id
private long id;
private String name;
private ToMany<Genre> genres;

[...]
}

@Entity
public class Genre {

@Id
private long id;
private String name;

[...]
}

我们都知道如何创建关系并保存它:

Movie movie = new Movie();
movie.setTitle("Star Wars");
movie.getGenres().add(new Genre("Sci-Fi");
box.put(movie);

但是是否有可能Movie用特定的查询所有对象Genre?喜欢

Box<Movie> box = boxStore.boxFor(Movie.class);

Query query = box.query()
  .equal(Genre_.name, "Sci-Fi") // note that I want to query the Movie-Box with Genre-properties
  .build();
List movies = query.find();

我的目标是以简单的方式找到所有具有特定类型的电影。有谁知道该怎么做,还是我必须自己查询所有电影并过滤结果?还是我必须以其他方式调整我的实体?

更新: 我在下面为一个工作示例准备了正确的标记答案:

    final Genre genreSciFi = genreBox.query().equal(Genre_.name, "Sci-Fi").build().findFirst();

    List<Movie> filteredMovies = movieBox.query().filter(new QueryFilter<Movie>() {
        @Override
        public boolean keep(@NonNull Movie entity) {
            return entity.getGenres().contains(genreSciFi);
        }
    }).build().find();

要使-Method 正常工作,请在 -Entity 中contains覆盖-Method:equalsGenre

@Override
public boolean equals(Object obj) {
    return obj instanceof Genre && ((Genre) obj).getId() == id && ((Genre) obj).getName().equals(name);
}
4

1 回答 1

3

不幸的是,这部分 API 还没有在 Java 中公开。我们希望尽快重构查询 API。

在这准备好之前,您可以使用查询过滤来解决问题。为简洁起见,使用 Java/Kotlin-ish 代码的示例:

Query query = movieBox.query().filter(movie -> { 
    return genres.contains(genre -> {
        return "Sci-Fi".equals(genre.getName())
    }
}).build()

(将在下次更新时使其在 Java 中类似。)

于 2017-09-28T13:41:24.640 回答