java - JPA加入spring boot应用

标签 java spring hibernate jpa join

我已阅读示例,但我有个人问题要问您。 我有 2 个表:

作用: 身份证,姓名 用户: id, login, name, role_id

角色实体

@Entity
@Table(name = "role")
public class Role {

@Id
@Column(name = "id")
private long id;

@Column(name = "name", length = 45)
private String name;

@OneToMany(cascade = CascadeType.ALL, mappedBy = "role")
private Set<User> user = new HashSet<>();

//getters and setters

用户实体

@Entity
@Table(name = "user")
public class User {

@Id
@GeneratedValue(strategy = GenerationType.AUTO)
@Column(name = "id",insertable = false, updatable = false)
private long id;

@Column(name = "login")
private String login;

@Column(name = "user_name")
private String userName;

@ManyToOne(fetch = FetchType.LAZY)
private Role role;

//getters and setters

和存储库:

public interface UserRepository extends JpaRepository<User, Long> {

String Q_GET_ALL_USERS = "from User u left join Role r on u.role_id=r.id";

@Query(Q_GET_ALL_USERS)
Collection<User> getAllUsers();

此代码显示:Caused by: java.lang.IllegalArgumentException: org.hibernate.hql.internal.ast.QuerySyntaxException: Path expected for join! [from com.example.jpa.model.User u left join Role r on u.role_id=r.id]

我怎么理解实体不能包含“id”(在我的例子中是 Role)作为引用,我应该删除这个字段。但是实体应该有“@Id”。

在这种情况下,我应该在“角色”中创建新列吗?或者我可以使用更漂亮的决定?

我把所有项目都放到了bb

最佳答案

要在 HQL (JPQL) 中使用连接,您不需要 on 子句

String Q_GET_ALL_USERS = "select u from User u left join u.role";

此查询没有任何意义,因为您没有在 where 子句中使用 role

如果你想让用户获得一个 fetched 角色,你可以使用 join fetch

String Q_GET_ALL_USERS = "select u from User u left join fetch u.role";

更新

UserRole 的架构不常用。我建议您建立从用户到角色的 @ManyToMany 关联,并从 Role

中删除所有 user 关联
@Entity
@Table(name = "user")
public class User {

    @ManyToMany(fetch = FetchType.LAZY)
    private Set<Role> roles;

}

@Entity
@Table(name = "role")
public class Role {

    @Id
    @Column(name = "id")
    private long id;

    @Column(name = "name", length = 45)
    private String name;

}

关于java - JPA加入spring boot应用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35149071/

相关文章:

spring - 如何使用 Spring MVC 测试避免 "Circular view path"异常

eclipse - 如何通过 eclipse 在 JUnit 测试中使用 persistence.xml 和 hibernate.cfg.xml?

java - 向哪个 Controller 扮演代表?

java - Google App Engine - 数据存储 java.lang.IllegalArgumentException : entity is too big

java - android gridview子项启动 Activity onclick

java - Hibernate:使用@SqlResultSetMapping 映射 native 查询的结果集

hibernate - Tomcat 忽略 persistence.xml

java - 打包java桌面应用程序(gradle)

java - 不活动期后连接超时问题

java - 在.NET 到 Java/Spring 中实现 RSA 公钥/私钥解密