java.sql.SQLException : Data truncated for column 'gender' at row 1 for enum

标签 java hibernate enums annotations

我正在使用注释将记录保存在 MySQL 数据库中。

在数据库端,我将列性别定义为性别ENUM('M','F')

定义枚举如下:

public enum Gender {
M,F;
}

在注释类中,我定义枚举属性如下:

@Column(name="gender")
@Enumerated(EnumType.ORDINAL) 
private Enum<Gender> gender=Gender.M;

我将属性保存在数据库中,如下所示:

employee.setGender(Gender.M);

但是当我运行程序时出现以下错误:

Hibernate: insert into Employees (birth_date, first_name,gender,hire_date,last_nane values
org.hibernate.exception.GenericJDBCException: Data truncated for column 'gender' at row 1
at org.hibernate.exception.internal.StandardSQLExceptionConverter.convert         
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:125)
at org.hibernate.engine.jdbc.spi.SqlExceptionHelper.convert(SqlExceptionHelper.java:110)
at org.hibernate.engine.jdbc.internal.proxy.AbstractStatementProxyHandler.continueInvocation    
at org.hibernate.engine.jdbc.internal.proxy.AbstractProxyHandler.invoke
at com.sun.proxy.$Proxy11.executeUpdate(Unknown Source)
at org.hibernate.id.IdentityGenerator$GetGeneratedKeysDelegate.executeAndExtract   
at org.hibernate.id.insert.AbstractReturningDelegate.performInsert
at org.hibernate.persister.entity.AbstractEntityPersister.insert
at org.hibernate.persister.entity.AbstractEntityPersister.insert  
at org.hibernate.action.internal.EntityIdentityInsertAction.execute
at org.hibernate.engine.spi.ActionQueue.execute(ActionQueue.java:362)
at org.hibernate.engine.spi.ActionQueue.addResolvedEntityInsertAction(ActionQueue.java:203)
at org.hibernate.engine.spi.ActionQueue.addInsertAction(ActionQueue.java:183)
at org.hibernate.engine.spi.ActionQueue.addAction(ActionQueue.java:167)

at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3609)
at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3541)
at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:2002)
at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:2163)
at com.mysql.jdbc.ConnectionImpl.execSQL(ConnectionImpl.java:2624)
at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:2127)
at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2427)
at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2345)
at com.mysql.jdbc.PreparedStatement.executeUpdate(PreparedStatement.java:2330)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.hibernate.engine.jdbc.internal.proxy.AbstractStatementProxyHandler.continueInvocation
... 25 more

我尝试使用字符串和序数,但错误仍然存​​在。

Ordinal 表示 int。我是否需要将性别类型的架构定义从 enum 更改为 String 或 int。 Hibernate 注释不适用于列类型枚举吗? 请帮助我解决这个问题。

最佳答案

什么Enum<Gender>Gender已经是Enum而这种类型的声明不是您想要的。
尝试更简单的:

@Column(name="gender")
@Enumerated(EnumType.ORDINAL) 
private Gender gender=Gender.M;

关于java.sql.SQLException : Data truncated for column 'gender' at row 1 for enum,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25113293/

相关文章:

java - spring data Rest如何将文档的版本和id发送到REST API客户端?

sql - 如何删除重复的别名 hibernate

swift - 与 Int 比较的枚举

swift - Swift 中的枚举和案例

java - 在设备上运行黑莓应用程序 'attempts to access a secure api'

java - 访问外部类这个实例

java - 使用变量名称标记形状的 2D 图形

java - hibernate : @JoinTable

java - Hibernate 4.x MYSQL Multi-Tenancy ID 生成问题

SQL:创建具有枚举列的外部表时出错