hibernate模板文件hbm.xml自定义映射类型
利用hibernate的hbm.xml生成实体库表,数据库采用国产的达梦数据库
·
项目场景
利用hibernate的hbm.xml生成实体库表,数据库采用国产的达梦数据库。达梦数据库使用clob类型原生驱动获取数据时对前端传数据时会发生【Infinite recursion】错误,所以产品要求使用longvarchar字段替代clob字段。然而hibernate的工厂类里不支持longvarchar字段,所以反映射到数据库时只有clob或者text类型。
附上映射类型表

解决办法
利用hibernate提供的自定义映射类型方法,实现UserType。指定返回类型为SQL中的LONGVARCHAR类型

模板文件配置

继承达梦的方言,声明SQL中的LONGVARCHAR类型对应”longvarchar”字段

生成配置中指定自定义的方言

即可生成LONGVARCHAR字段

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。
更多推荐

所有评论(0)