今天在项目中发现了一个实体类中有枚举类型的属性,并且在声明的时候加上了
@Enumerated(EnumType.STRING)
的注解。
同事在查询的时候发现报了错误,于是就百度了一下这个注解的意义,发现这个是hibernate的一个枚举注解。
Error attempting to get column 'level' from result set. Cause: java.lang.IllegalArgumentException: No enum constant com.kylin.blitz.dao.enums.MemberLevel.5
org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.executor.result.ResultMapException:
@Enumerated(EnumType.STRING)
EnumType有两个属性,一个是STRING,一个是ORDINAL,当使用的是STRING的时候,数据库对应保存的是注解的名称
当注解使用的是ORDINAL的时候,数据库对应保存的是注解的值
在这里写下记录一下,使用枚举类当做实体类对应数据库的时候,可以使用hibernate的注解@Enumerate进行映射,具体数据库保存的是枚举的名称还是枚举的值,则根据注解里面的EnumType来决定,STRING保存的是名称,ORDINAL保存的是值。