期望两个实体Movie
和Genre
:
@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:equals
Genre
@Override
public boolean equals(Object obj) {
return obj instanceof Genre && ((Genre) obj).getId() == id && ((Genre) obj).getName().equals(name);
}