java - JPA 用户、角色、多对多 hibernate 关系

标签 java spring hibernate jpa

我正在使用 JPA+Hibernate+SpringBoot+PostgreSQL 来创建不同实体之间的关系,但我遇到了很多错误,包括看起来像 SQL 的错误,但应用程序还是启动了。我是否正确编码了 manyToMany 关系?可以有很多用户,每个用户可以有多个角色。也许 OneToMany 更好?

我正在使用“spring-boot-starter-data-jpa”

到目前为止,这些是我仅有的 hibernate 文件。

角色.java

@Entity(name = "role")
public class Role implements java.io.Serializable {
    /**
     * 
     */
    private static final long serialVersionUID = -5525359165179861924L;
    @Id
    @GeneratedValue(strategy=GenerationType.AUTO)
    @Column(name = "id")
    int id;

    private String role;

    @ManyToMany(mappedBy = "roles",fetch = FetchType.LAZY)
    private Set<User> users;


    public Role(String role) {
        super();
        this.role = role;
    }

    public void setId(int id){
        this.id = id;
    }

    public int getId(){
        return id;
    }

    public String getRole() {
        return role;
    }

    public void setRole(String role) {
        this.role = role;
    }

    public Set<User> getUsers() {
        return users;
    }

    public void setUser(Set<User> users) {
        this.users = users;
    }
}

用户.java

@Entity
@Table(name = "user")
public class User implements java.io.Serializable {

    private static final long serialVersionUID = 4910225916550731448L;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "id", unique = true, nullable = false)
    private Long id;

    @Column(name = "created")
    Date created;

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

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

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

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

    @Column(name = "enabled")
    private int enabled;

    @ManyToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
    @JoinTable(joinColumns = @JoinColumn(name = "userId", referencedColumnName = "id"), 
    inverseJoinColumns = @JoinColumn(name = "roleId", referencedColumnName = "id"))
    private Set<Role> roles;

    protected User(){
        roles = new HashSet<Role>();
    }

    public Set<Role> getRoles(){
        return roles;
    }

    public void setRoles(Set<Role> roles){
        this.roles = roles;
    }

    public User(String firstName, String lastName, String email, String username, Set<Role> roles) {
        this.firstName = firstName;
        this.lastName = lastName;
        this.email = email;
        this.username = username;
        this.roles = roles;
    }
}

我得到的错误:

2017-04-24 22:49:19.163  WARN 20488 --- [  restartedMain] org.hibernate.orm.deprecation            : HHH90000014: Found use of deprecated [org.hibernate.id.SequenceGenerator] sequence-based id generator; use org.hibernate.id.enhanced.SequenceStyleGenerator instead.  See Hibernate Domain Model Mapping Guide for details.
2017-04-24 22:49:19.167  WARN 20488 --- [  restartedMain] org.hibernate.orm.deprecation            : HHH90000014: Found use of deprecated [org.hibernate.id.SequenceGenerator] sequence-based id generator; use org.hibernate.id.enhanced.SequenceStyleGenerator instead.  See Hibernate Domain Model Mapping Guide for details.
2017-04-24 22:49:19.438  INFO 20488 --- [  restartedMain] org.hibernate.tuple.PojoInstantiator     : HHH000182: No default (no-argument) constructor for class: com.example.domain.Role (class must be instantiated by Interceptor)
2017-04-24 22:49:19.527  INFO 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000227: Running hbm2ddl schema export
Hibernate: alter table user_roles drop constraint FKrhfovtciq1l558cw6udg0h0d3
2017-04-24 22:49:19.531 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000389: Unsuccessful: alter table user_roles drop constraint FKrhfovtciq1l558cw6udg0h0d3
2017-04-24 22:49:19.531 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : ERROR: relation "user_roles" does not exist
Hibernate: alter table user_roles drop constraint FK55itppkw3i07do3h7qoclqd4k
2017-04-24 22:49:19.532 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000389: Unsuccessful: alter table user_roles drop constraint FK55itppkw3i07do3h7qoclqd4k
2017-04-24 22:49:19.533 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : ERROR: relation "user_roles" does not exist
Hibernate: drop table if exists role cascade
Hibernate: drop table if exists user cascade
2017-04-24 22:49:19.535 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000389: Unsuccessful: drop table if exists user cascade
2017-04-24 22:49:19.535 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : ERROR: syntax error at or near "user"
  Position: 22
Hibernate: drop table if exists user_roles cascade
Hibernate: drop sequence hibernate_sequence
2017-04-24 22:49:19.537 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000389: Unsuccessful: drop sequence hibernate_sequence
2017-04-24 22:49:19.538 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : ERROR: sequence "hibernate_sequence" does not exist
Hibernate: create sequence hibernate_sequence start 1 increment 1
Hibernate: create table role (id int4 not null, role varchar(255), primary key (id))
Hibernate: create table user (id int8 not null, created timestamp, email varchar(150), enabled int4, first_name varchar(100), last_name varchar(100), username varchar(150), primary key (id))
2017-04-24 22:49:19.564 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000389: Unsuccessful: create table user (id int8 not null, created timestamp, email varchar(150), enabled int4, first_name varchar(100), last_name varchar(100), username varchar(150), primary key (id))
2017-04-24 22:49:19.564 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : ERROR: syntax error at or near "user"
  Position: 14
Hibernate: create table user_roles (user_id int8 not null, role_id int4 not null, primary key (user_id, role_id))
Hibernate: alter table user_roles add constraint FKrhfovtciq1l558cw6udg0h0d3 foreign key (role_id) references role
Hibernate: alter table user_roles add constraint FK55itppkw3i07do3h7qoclqd4k foreign key (user_id) references user
2017-04-24 22:49:19.585 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000389: Unsuccessful: alter table user_roles add constraint FK55itppkw3i07do3h7qoclqd4k foreign key (user_id) references user
2017-04-24 22:49:19.585 ERROR 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : ERROR: syntax error at or near "user"
  Position: 100
2017-04-24 22:49:19.585  INFO 20488 --- [  restartedMain] org.hibernate.tool.hbm2ddl.SchemaExport  : HHH000230: Schema export complete

最佳答案

首先你应该删除你的数据库或者改变你的 hibernate 配置来创建

<prop key="hibernate.hbm2ddl.auto">create</prop>

错误是

ERROR: relation "user_roles" does not exist

所以你应该将 ManyToMany 命名为 user_roles:

@JoinTable(name="user_roles",
        joinColumns = {@JoinColumn(name="user_id", referencedColumnName="id")},
        inverseJoinColumns = {@JoinColumn(name="role_id", referencedColumnName="id")}
    )
    private List<Role> roles;

在我的项目中,用户实体是:

  @Entity
@Table(name = "user")
public class User extends AbstractPersistable<Long>{


    private static final long serialVersionUID = 1L;


    @Column(name = "USER_NAME", unique = true)
    private String username;
    @Column(name = "PASSWORD")
    private String password;



    @ManyToMany(cascade=CascadeType.ALL,fetch=FetchType.EAGER)
    @JoinTable(name="user_roles",
        joinColumns = {@JoinColumn(name="user_id", referencedColumnName="id")},
        inverseJoinColumns = {@JoinColumn(name="role_id", referencedColumnName="id")}
    )
    private List<Role> roles;



    public String getUsername() {
        return username;
    }



    public void setUsername(String username) {
        this.username = username;
    }



    public String getPassword() {
        return password;
    }



    public void setPassword(String password) {
        this.password = password;
    }



    public List<Role> getRoles() {
        return roles;
    }



    public void setRoles(List<Role> roles) {
        this.roles = roles;
    }



    public User(String username, String password, List<Role> roles) {
        super();
        this.username = username;
        this.password = password;
        this.roles = roles;
    }



    public User() {
        super();
    }
}

和角色:

 @Entity
@Table(name = "roles")
public class Role extends AbstractPersistable<Long> {

    private static final long serialVersionUID = 1L;

    private String role;

    public String getRole() {
        return role;
    }

    public void setRole(String role) {
        this.role = role;
    }

    public Role() {
    }

    public Role(String role) {
        this.role = role;
    }

}

关于java - JPA 用户、角色、多对多 hibernate 关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43600797/

相关文章:

java - 点击后服务不停止

java - JNI 分配损坏的堆

java - Hibernate Annotation下使用命名查询有什么好处

java - 从mysql获取大数据时出现连接异常

java - 从多对多关系的表中删除记录?

java - 关于如何获得2个相同尺寸的组件进行水平线性布局的一些疑问?

java - ANTLR:循环与字符 '%' 处的任何内容都不匹配

spring - 正在运行的测试在没有进行任何更改的情况下就停止了,这有什么问题?

java - Spring 3如何以属性文件的间隔运行计划任务

java - 使用 spring、hibernate 和 mysql 通过嵌套事务创建重复对象