Spring Boot Data JPA manyToMany добавляет выбрасываемые элементы UnsupportedOperationException - PullRequest
0 голосов
/ 08 сентября 2018

Company.java:

@Entity
@JsonIdentityInfo(generator= ObjectIdGenerators.PropertyGenerator.class, property="id")
@Data
public class Company {
    @Id
    @GeneratedValue(generator="system-uuid")
    @GenericGenerator(name="system-uuid", strategy = "uuid")
    String id;

    String name;

    @ManyToMany
    @LazyCollection(LazyCollectionOption.FALSE)
    private List<User> employees = new ArrayList<>();
    // Snip
}

Пользователь

@Entity
@JsonIdentityInfo(generator= ObjectIdGenerators.PropertyGenerator.class, property="id")
@Data
public class User {
    @Id @GeneratedValue(generator="system-uuid")
    @GenericGenerator(name="system-uuid", strategy = "uuid")
    String id;

    @NotNull
    String email;

    @NotNull
    Date created = new Date();

    @ManyToMany(mappedBy="employees")
    @LazyCollection(LazyCollectionOption.FALSE)
    List<Company> employedByCompanies = new ArrayList<>();
    // Snip
}

Хранилища:

public interface CompanyRepository extends CrudRepository<Company, String> {
}

public interface UserRepository extends CrudRepository<User, String> {
}

Итак, я загружаю компанию из БД и делаю:

company.getEmployees().add(timesheetUser);

Я получаю исключение:

java.lang.UnsupportedOperationException
    at java.util.AbstractList.add(AbstractList.java:148)

Почему JPA не использует класс, который я могу обновить?

Вот мой файл Gradle:

buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath("org.springframework.boot:spring-boot-gradle-plugin:2.0.3.RELEASE")
    }
}

apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'idea'
apply plugin: 'org.springframework.boot'
apply plugin: 'io.spring.dependency-management'

bootJar {
    baseName = 'timesheets-rest-service'
    version =  '0.1.0'
}

repositories {
    mavenCentral()
}

sourceCompatibility = 1.8
targetCompatibility = 1.8

dependencies {
    compile("io.jsonwebtoken:jjwt-api:0.10.5")
    compile("io.jsonwebtoken:jjwt-impl:0.10.5")

    compile("org.springframework.boot:spring-boot-starter-web")
    compile("org.springframework.boot:spring-boot-starter-security")
    compile("org.springframework.cloud:spring-cloud-starter-config")
    compile("org.springframework.boot:spring-boot-starter-data-jpa")
    compile('org.springframework.boot:spring-boot-starter-actuator')

    compile group: 'org.springframework.security.oauth.boot', name: 'spring-security-oauth2-autoconfigure', version: '2.0.3.RELEASE'

    compile("com.h2database:h2")
    compile group: 'org.apache.commons', name: 'commons-lang3', version: '3.7'
    compile group: 'com.google.guava', name: 'guava', version: '26.0-jre'
    compileOnly 'org.projectlombok:lombok:1.18.2'
    runtime 'io.jsonwebtoken:jjwt-impl:0.10.5',
            // Uncomment the next line if you want to use RSASSA-PSS (PS256, PS384, PS512) algorithms:
            //'org.bouncycastle:bcprov-jdk15on:1.60',
            'io.jsonwebtoken:jjwt-jackson:0.10.5'

    testCompile('org.springframework.boot:spring-boot-starter-test')
}

dependencyManagement {
    imports {
        mavenBom "org.springframework.cloud:spring-cloud-dependencies:Finchley.BUILD-SNAPSHOT"
    }
}

repositories {
    maven {
        url 'https://repo.spring.io/libs-milestone'
    }
    maven {
        url 'https://repo.spring.io/libs-snapshot'
    }
}

1 Ответ

0 голосов
/ 28 октября 2018

По какой-то причине мне пришлось изменить List на Set, и это работает.

Как это:

@Entity
@JsonIdentityInfo(generator= ObjectIdGenerators.PropertyGenerator.class, property="id")
@Data
public class User {
    @Id @GeneratedValue(generator="system-uuid")
    @GenericGenerator(name="system-uuid", strategy = "uuid")
    String id;

    @NotNull
    String email;

    @NotNull
    Date created = new Date();

    @ManyToMany(mappedBy="employees")
    @LazyCollection(LazyCollectionOption.FALSE)
    // List DOES NOT WORK HERE!
    Set<Company> employedByCompanies = new HashSet<>();
    // Snip
}

Понятия не имею, почему ...

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...