Hibernate не добавляет ссылочное ограничение при отображении класса Java (приложение Spring Boot) - PullRequest
0 голосов
/ 09 октября 2018

Впервые работая с Spring Boot и Hibernate.

Я пытаюсь сопоставить мои User.java и Role.java классы с базой данных MySQL вNetBeans.Все работает просто отлично, за исключением одной детали.

Когда я захожу в сгенерированные таблицы с помощью интерфейса менеджера баз данных NetBeans на вкладке Services и пытаюсь вручную добавить строку в таблицу user_role (результат @ManyToMany), она позволяетя, даже без пользователя или роли, созданной еще.Я ожидаю, что он выдаст мне сообщение об ошибке, в котором говорится, что идентификатор пользователя, который я вставляю, не существует, например.

Теперь я пришел из фона PostgreSQL / Doctrine, и, возможно, поэтому он немного странныйдля меня, потому что, если бы я должен был сделать это в pgAdmin ну, это большой нет нет.

Пожалуйста, если это поведение по умолчанию, скажите мне, как переопределить его, если нет, здесьмой код с ошибкой где-то.

User.java

package hello;

import java.util.Set;
import javax.persistence.Access;
import javax.persistence.AccessType;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.Transient;

@Entity // This tells Hibernate to make a table out of this class
public class User {

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Integer id;

    private String name;
    private String email;
    private String username;
    private String password;
    private String passwordConfirm;

    @ManyToMany(targetEntity = Role.class)
    @Access(AccessType.FIELD)
    @JoinTable(name = "user_role", joinColumns = @JoinColumn(name = "user_id", referencedColumnName = "id"),
            inverseJoinColumns = @JoinColumn(name = "role_id", referencedColumnName = "id"))
    private Set<Role> roles;

    public Integer getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    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;
    }

    @Transient
    public String getPasswordConfirm() {
        return passwordConfirm;
    }

    public void setPasswordConfirm(String passwordConfirm) {
        this.passwordConfirm = passwordConfirm;
    }

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

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

}

Role.java

package hello;

import javax.persistence.*;
import java.util.Set;

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

    private Long id;
    private String name;

    @ManyToMany(targetEntity = User.class, mappedBy = "roles")
    @Access(AccessType.FIELD)
    private Set<User> users;

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    public Long getId() {
        return id;
    }

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

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

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

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

Если вам нужна дополнительная информация, пожалуйста, спросите.

...