- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在获取 spring-data-jpa
中的惰性 @ManyToMany
关联时遇到问题。我有一个电影列表,它与喜爱这部电影的用户以及流派列表有关联:
@Entity
@Table("movie")
public class Movie {
...
@ManyToMany(fetch = FetchType.EAGER)
@JoinTable(...)
private List<Genre> genres;
@ManyToMany
@JoinTable(name = "users_movies",
joinColumns = @JoinColumn(name = "movie_id", referencedColumnName = "id"),
inverseJoinColumns = @JoinColumn(name = "user_id", referencedColumnName = "id"))
private List<User> users = new ArrayList<>;
}
流派还与将该流派标记为最喜爱的用户相关联:
@Entity
@Table("genre")
public class Genre {
....
@ManyToMany
@JoinTable(name = "users_genres",
joinColumns = @JoinColumn(name = "genre_id", referencedColumnName = "id"),
inverseJoinColumns = @JoinColumn(name = "user_id", referencedColumnName = "id"))
private List<User> users;
}
我有一个具有以下方法/查询的存储库,它必须按最喜欢的类型返回所有电影并加载电影的用户,以便我可以显示用户是否已将电影标记为最喜欢的:
@Query(value = "SELECT movie FROM Movie movie " +
"JOIN movie.genres genre JOIN genre.users grenreUser " +
"LEFT JOIN FETCH movie.users " +
"WHERE grenreUser.id = :userId",
countQuery = "SELECT COUNT(movie) FROM Movie movie " +
"JOIN movie.genres genre JOIN genre.users grenreUser " +
"LEFT JOIN movie.users " +
"WHERE grenreUser.id = :userId")
Page<Movie> getAllMoviesByFavoriteGenres(@Param("userId") String userId, Pageable);
但是这里我遇到了问题,执行此查询后 movie.getUsers()
为空。
我found使用 @EntityGraph
可能会有所帮助,但它并没有帮助 movie.getUsers()
关联仍然为空。
为了测试,我还尝试将此关联设置为 FetchType.EAGER
,但它仍然是空的。
我没有主意,所以我将不胜感激任何帮助。
更新:这不可能是用户不在数据库中的问题,因为我有另一个查询,该查询仅提取用户在 Collection 夹用户类型中标记为 Collection 夹的电影。因此,如果用户不存在于数据库中,查询将返回空结果,但尽管 movie.getUsers()
为空,但我确实得到了结果。这是方法/查询:
@Query(value = "SELECT movie FROM Movie movie " +
"JOIN movie.genres genre " +
"JOIN FETCH movie.users user " +
"WHERE user.id = :userId AND :userId MEMBER OF genre.users",
countQuery = "*same but with count*")
Page<Movie> getAllFavoriteMoviesByFavoriteGenres(@Param("userId") String userId, Pageable);
最佳答案
是的,单向映射应该可以工作。我对您正在做的事情的基本示例没有任何问题。这应该是一个很好的起点,可以帮助您找出差异所在。我注意到我没有在 countQuery
中加入 movie.users
。
@Entity
public class Movie {
@Id @GeneratedValue private Long id;
@ManyToMany
private Set<Genre> genres;
@ManyToMany
private Set<User> users;
@Entity
public class Genre {
@Id @GeneratedValue private Long id;
@ManyToMany
private Set<User> users;
@Entity
public class User {
@Id @GeneratedValue private Long id;
和存储库:
public interface MovieRepository extends JpaRepository<Movie, Long> {
@Query(value = "SELECT movie FROM Movie movie " +
"JOIN movie.genres genres JOIN genres.users users LEFT JOIN FETCH movie.users " +
"WHERE users.id = :userId",
countQuery = "SELECT COUNT(movie) FROM Movie movie " +
"JOIN movie.genres genres JOIN genres.users users " +
"WHERE users.id = :userId")
Page<Movie> getAllMoviesByFavoriteGenres(@Param("userId") Long userId, Pageable page);
并使用它:
@Override
public void run(String... args) throws Exception {
create();
System.out.println("something");
Page<Movie> movies = movieRepo.getAllMoviesByFavoriteGenres(1L, PageRequest.of(0, 10));
movies.forEach(System.out::println);
}
private void create() {
User u1 = new User();
userRepo.save(u1);
Set<User> users = Collections.singleton(u1);
Genre g1 = new Genre();
g1.setUsers(users);
genreRepo.save(g1);
Set<Genre> genres = Collections.singleton(g1);
Movie m1 = new Movie();
m1.setGenres(genres);
m1.setUsers(users);
movieRepo.save(m1);
}
关于java - spring-data-jpa 中的 JOIN FETCH 不会获取惰性关联,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56134473/
我正在运行此代码并在没有互联网连接的情况下进行测试: fetch(url, options) .then(res => { // irrelevant, as catch happens
function fetchHandler(evt) { console.log('request:' + evt.request.url); dealWithRequest(evt)
我在 AdventureWorks2016 上执行了两个示例查询,并得到了相同的结果。那么什么时候应该使用 NEXT 或 FIRST 关键字? select LastName + ' ' + Firs
我有以下查询: @Query("SELECT new de.projectemployee.ProjectEmployee(employee) " + "FROM ProjectEmpl
我正在尝试使用 fetch on react 来实现客户端登录。 我正在使用护照进行身份验证。我使用的原因 fetch而不是常规 form.submit() , 是因为我希望能够从我的快速服务器接收错
我正在尝试将我的 Aurelia 项目从 beta 版本升级到 3 月版本。 我遇到的错误之一是: Cannot find name 'Request'. 谷歌搜索会在 GitHub 上显示此问题:h
见标题。在我们的react项目中调用fetch时,一位(现已离职)开发人员最初使用from fetch to window.fetch。我不确定两者之间的区别,也无法在网上找到任何结论(W3Schoo
这个问题在这里已经有了答案: HTTP status code 401 even though I’m sending credentials in the request (1 个回答) How
这是代码片段: var fetch = require("node-fetch"); var fetchMock = require("fetch-mock"); function setupMock
我在这里看到了两种不同的抓取方式: https://github.com/github/fetch https://github.com/matthew-andrews/isomorphic-fetc
以下git命令有什么区别? git fetch origin 和 git fetch --all 从命令行运行它们看起来就像它们做同样的事情。 最佳答案 git fetch origin 仅从 ori
我有一个不断改变值的动态 json。我想用该数据绘制图表所以我将动态数据存储到数组然后用该数组绘制图表。目前我创建了 serinterval 用于从 api 获取新数据。但问题是如果新数据没有,它会再
我有一个很大的 JSON blob,我想预先加载我的网页。为此,我添加了 到我的页面。我也有一个 JS 请求来获取相同的 blob。 这不起作用,控制台报告: [Warning] The resour
我们在单页 JavaScript 应用程序发出 fetch 请求时遇到不一致的客户端错误。值得注意的是,它们都是同源请求。 let request = new Request(url, options
我是 ReactJS 的新手,我一直在阅读如何从 api 获取和发布数据。我见过这两个,但我不知道该用什么以及两者之间有什么区别?我读了它,但我不确定我会用什么。谢谢! react-fetch wha
Doctrine中注解@ManyToOne中的fetch="EAGER"和fetch="LAZY"有什么区别? /** * @ManyToOne(targetEntity="Cart", casca
我想要获取一个 api,然后调用另一个 api。在 javascript 中使用这样的代码是否明智? fetch(url, { method: 'get', }).then(function(re
我有一个组件,它依赖于 2 个端点来检索所需程序的名称。我有 2 个端点。第一个端点返回程序列表,它是一个对象数组。目前,它仅返回 4 个节目(2 个节目 ID 为“13”,另外两个节目 ID 为“1
我的应用程序从外部源(配置文件)接收查询,因此它必须从查询结果中获取列。我有一些代码: typedef union _DbField { text text[512]; sword i
我有一个实体A,它与实体B有对多关系。 Entity A -->> Entity B 我需要在多个屏幕上引用一对多关系的计数。此外,我可以多次从 Entity A
我是一名优秀的程序员,十分优秀!