집 >데이터 베이스 >MySQL 튜토리얼 >MySQL Enum 열에 매핑할 때 Hibernate가 Enum 값을 유지하는지 확인하는 방법은 무엇입니까?
Hibernate에서 Enum 값 보존: 잘못된 열 유형 문제 해결
데이터 지속성 영역에서 데이터 모델, 데이터베이스 스키마 간의 호환성 보장 , 각각의 매핑이 필수적입니다. Java에서 열거 유형으로 작업할 때 Hibernate가 이러한 열거형을 기본 데이터베이스에 매핑하는 방법을 설정하는 것이 중요합니다.
귀하의 경우에는 MySQL 열을 열거형으로 정의하고 Java에서 해당 열거형을 생성했습니다. 암호. 그러나 다음 오류가 발생합니다. "성별 열에 대한 MyApp.Person의 열 유형이 잘못되었습니다. 발견: 열거형, 예상: 정수." 이 오류는 @Enumerated 주석의 사양에 따라 열거형이 서수 또는 문자열로 처리되기 때문에 Hibernate가 Gender 열이 정수일 것으로 예상할 때 발생합니다.
이 문제를 해결하려면 명시적으로 다음을 지정할 수 있습니다. columnDefinition 속성을 사용하는 열 정의:
<code class="java">@Column(columnDefinition = "enum('MALE','FEMALE')") @Enumerated(EnumType.STRING) private Gender gender;</code>
열 정의를 제공함으로써 Hibernate가 열 유형을 추측하지 않고 지정된 정의를 준수하도록 지시합니다.
또는 다음과 같은 경우 스키마를 생성하기 위해 Hibernate를 사용하지 않는 경우, 임의의 값으로 설정하여 열 정의 값의 필요성을 제거할 수 있습니다.
<code class="java">@Column(columnDefinition = "enum('DUMMY')") @Enumerated(EnumType.STRING) private ManyValuedEnum manyValuedEnum;</code>
이런 방식으로 열거형 값이 Java에서 보존되도록 할 수 있습니다. enum을 사용하여 Liquibase 또는 SQL 스크립트를 적절하게 동기화하세요.
위 내용은 MySQL Enum 열에 매핑할 때 Hibernate가 Enum 값을 유지하는지 확인하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!