>  기사  >  데이터 베이스  >  MySQL Enum 열에 매핑할 때 Hibernate가 Enum 값을 유지하는지 확인하는 방법은 무엇입니까?

MySQL Enum 열에 매핑할 때 Hibernate가 Enum 값을 유지하는지 확인하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-02 07:58:29510검색

How to Ensure Hibernate Preserves Enum Values When Mapping to a MySQL Enum Column?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.