java .lang.ClassCastException: java .lang.String нельзя привести к java .lang.Enum - PullRequest
0 голосов
/ 16 апреля 2020

Я получаю эту ошибку при попытке сохранить сущность 'UserAccount' в таблице базы данных.

@Entity
@Table(name = "user_account")
public class UserAccount extends BaseEntity {

  @OneToMany(cascade = CascadeType.ALL)
  @JoinColumn(name = "useraccount_id")
  @MapKeyEnumerated(EnumType.STRING)
  private Map<PhoneType, PhoneNumber> phones = new HashMap<PhoneType, PhoneNumber>();

  //... other attributes
  //... default constructor, getters and setters
}
public enum PhoneType {
  HOME("home"),
  MOBILE("mobile"),
  FAX("fax"),
  WORK("work");

  private String value;

  PhoneType(String value) {
     this.value = value;
  }

  @JsonValue
  public String getValue() {
      return value;
  }
}
@Entity
@Table(name = "phone_number")
public class PhoneNumber extends BaseEntity {

  private String areaCode;
  private String number;

  //... default constructor, getters and setters
}

и наконец ..

public class UserAccountRepository {

    @Inject
    EntityManager entityManager;

    @Override
    public UserAccount save(UserAccount userAccount) {
        if (userAccount.getId() == null) {
            entityManager.persist(userAccount);
        } else {
            userAccount = entityManager.merge(userAccount);
        }
        return userAccount;
    }

  //.. other methods
}
Caused by: java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Enum
    at org.eclipse.persistence.mappings.converters.EnumTypeConverter.convertObjectValueToDataValue(EnumTypeConverter.java:165)
    at org.eclipse.persistence.mappings.foundation.AbstractDirectMapping.extractIdentityFieldsForQuery(AbstractDirectMapping.java:568)
    at org.eclipse.persistence.internal.queries.MappedKeyMapContainerPolicy.getKeyMappingDataForWriteQuery(MappedKeyMapContainerPolicy.java:145)
    at org.eclipse.persistence.mappings.OneToManyMapping.updateTargetRowPostInsertSource(OneToManyMapping.java:1425)
    at org.eclipse.persistence.mappings.OneToManyMapping.performDataModificationEvent(OneToManyMapping.java:936)
    at org.eclipse.persistence.internal.sessions.CommitManager.commitAllObjectsWithChangeSet(CommitManager.java:162)
    at org.eclipse.persistence.internal.sessions.AbstractSession.writeAllObjectsWithChangeSet(AbstractSession.java:4387)
    at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.commitToDatabase(UnitOfWorkImpl.java:1493)
    at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.commitToDatabaseWithChangeSet(UnitOfWorkImpl.java:1583)
    at org.eclipse.persistence.internal.sessions.UnitOfWorkImpl.issueSQLbeforeCompletion(UnitOfWorkImpl.java:3258)
    at org.eclipse.persistence.internal.sessions.RepeatableWriteUnitOfWork.issueSQLbeforeCompletion(RepeatableWriteUnitOfWork.java:357)
    at org.eclipse.persistence.transaction.AbstractSynchronizationListener.beforeCompletion(AbstractSynchronizationListener.java:160)
    at org.eclipse.persistence.transaction.JTASynchronizationListener.beforeCompletion(JTASynchronizationListener.java:70)
    at com.sun.enterprise.transaction.JavaEETransactionImpl.commit(JavaEETransactionImpl.java:452)
    ... 94 more

Другие вопросы с такой же ошибкой предлагают добавить @Enumerated (EnumType.STRING) к атрибуту типа Enum, я использовал @MapKeyEnumerated(EnumType.STRING) на карте телефонов, но я все еще вижу эту ошибку. Любые подсказки, где я ошибаюсь?

Пожалуйста, дайте мне знать, если я не задавал вопрос согласно руководству SO, я исправлю его (так как это мой 1-й вопрос).

1 Ответ

2 голосов
/ 16 апреля 2020

Я внес изменение в класс PhoneNumber, как показано ниже

@Entity
@Table(name = "phone_number")
public class PhoneNumber extends BaseEntity {

  private PhoneType type;
  private String areaCode;
  private String number;

  //... default constructor, getters and setters
}

, а затем добавил @MapKey(name = "type") в UserAccount, как показано ниже.

@OneToMany(cascade = CascadeType.ALL)
    @JoinColumn(name = "useraccount_id")
    @MapKeyEnumerated(EnumType.STRING)
    @MapKey(name = "type")
    private Map<PhoneType, PhoneNumber> phones = new HashMap<PhoneType, PhoneNumber>();

С этими изменениями Теперь я могу успешно сохранить объект UserAccount в таблицах БД.

...