>  기사  >  데이터 베이스  >  MySQL\'enum' 열로 작업할 때 Hibernate에서 Enum 유형을 유지하는 방법은 무엇입니까?

MySQL\'enum' 열로 작업할 때 Hibernate에서 Enum 유형을 유지하는 방법은 무엇입니까?

DDD
DDD원래의
2024-10-31 11:28:29217검색

How to Preserve Enum Type in Hibernate When Working with MySQL's `enum` Column?

Hibernate의 Enum 지속성: Enum 유형 보존

문제

다음 설정을 고려하십시오: "gender enum( '남성', '여성')", 해당 Java 열거형 "Gender" 및 "성별 성별"이 있는 Person 엔터티입니다. 애플리케이션을 부팅하려고 하면 다음 오류가 발생합니다. "성별 열에 대한 MyApp.Person의 열 유형이 잘못되었습니다. 발견: 열거형, 예상: 정수."

원인 및 해결 방법

기본적으로 , Hibernate는 열거된 필드가 정수로 저장될 것으로 예상합니다. 열거형 유형이 데이터베이스에서 유지되어야 함을 지정하려면 다음 주석을 사용하십시오.

<code class="java">@Column(columnDefinition = "enum('MALE','FEMALE')")
@Enumerated(EnumType.STRING)
private Gender gender;</code>

또는 스키마 생성을 Liquibase 또는 SQL 스크립트에 위임하려는 경우 다음에 대한 더미 값을 제공할 수 있습니다. 컬럼 정의:

<code class="java">@Column(columnDefinition = "enum('DUMMY')")
@Enumerated(EnumType.STRING)
private ManyValuedEnum manyValuedEnum;</code>

이는 Hibernate가 Java 열거형 및 데이터베이스 스키마 동기화 도구에 의존하여 올바른 열거형 값을 유지하도록 보장합니다.

위 내용은 MySQL\'enum' 열로 작업할 때 Hibernate에서 Enum 유형을 유지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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