如何使用 Hibernate 保留 MySQL 数据库中的枚举类型?

Mary-Kate Olsen
发布: 2024-10-30 19:40:03
原创
720 人浏览过

How to Preserve Enum Type in MySQL Database with Hibernate?

Hibernate 中的枚举:在 MySQL 数据库中保留枚举类型

在要映射到数据库的实体中定义枚举字段时,开发人员当 Hibernate 期望整数数据类型而枚举列在数据库中定义为枚举时,可能会遇到问题。要解决此冲突,必须显式通知 Hibernate 将列视为枚举而不是整数。

在给定的示例中,已创建一个枚举“com.mydomain.myapp.enums.Gender”来表示“人”实体的“性别”属性。但是,尝试在数据库中保留此枚举类型会导致错误:“MyApp.Person 中性别列的列类型错误。发现:枚举,预期:整数。”

要解决此问题,Hibernate 必须明确提供正确的列定义。这可以通过使用“@Column”和“@Enumerated”注释对“gender”字段进行注释,将列定义指定为枚举并将枚举类型指定为字符串来实现。这是一个例子:

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

通过显式提供此列定义,Hibernate 将不再尝试猜测数据类型。这种方法可确保枚举类型保留在 MySQL 数据库中,从而使映射能够正确运行。

以上是如何使用 Hibernate 保留 MySQL 数据库中的枚举类型?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!