开发者社区> 问答> 正文

hibernate对enum反序列化出错?报错

定义的枚举类:

public enum EApplyLevel {
    AAA,
    BBB
}



实体类:

public class User {
    public EApplyLevel level;

    @Enumerated(EnumType.ORDINAL)
    @Column(name="APPLYLEVEL", length=1)
    public EApplyLevel getApplyLevel() {
        return applyLevel;
    }

}



保存(查看数据库,成功保存了,level对应的字段为1:

TUser user = ...
user.setEApplyLevel(EApplyLevel.BBB);
save()



查询时报错:

No enum const class com.....EApplyLevel.1



不知道什么原因?

感觉枚举用起来还是有些局限啊。

展开
收起
爱吃鱼的程序员 2020-06-14 18:11:46 494 0
1 条回答
写回答
取消 提交回答
  • https://developer.aliyun.com/profile/5yerqm5bn5yqg?spm=a2c6h.12873639.0.0.6eae304abcjaIB

    估计需要在写枚举的时候,需要写构造方法或其他可以将int值与枚举之间转换的方法

    知道问题了。

    数据库对应的字段类型是varchar2,而<spanstyle="font-family:Consolas,'BitstreamVeraSansMono','CourierNew',Courier,monospace;font-size:14.44444465637207px;line-height:15.399999618530273px;background-color:#FFFFFF;">EnumType.ORDINAL对应的应该是数字。

    <spanstyle="font-family:Consolas,'BitstreamVeraSansMono','CourierNew',Courier,monospace;font-size:14.44444465637207px;line-height:15.399999618530273px;background-color:#FFFFFF;">解决办法,改数据库,把varchar2改成number。

    <spanstyle="font-family:Consolas,'BitstreamVeraSansMono','CourierNew',Courier,monospace;font-size:14.44444465637207px;line-height:15.399999618530273px;background-color:#FFFFFF;">如果数据库不能改,不知道还有没有什么好的办法

    2020-06-14 18:12:04
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载