我的应用程序使用jhipster与mysql和liquibase,mysql版本是5.7.20,支持json列,我使用对象映射器映射json列和java对象,它可以工作,列类型是json,但是当涉及liquibase时(./mvnw package -Pprod dockerfile:build),会出现“未知数据类型'JSON'”之类的异常测试将失败,不会生成 docker 镜像。
我在 20180410012441_added_entity_Ability.xml 中对该 json 列进行了一些更改:
<column name="abilities" type="json">
<constraints nullable="true"/>
</column>
在我的域类中,json相关字段如下:
@Type(type = "json")
@Column(columnDefinition = "json")
private List<Skill> abilities = new ArrayList<>();
我怀疑问题与 xml 列/类型定义有关,liquibase 不支持 json 关键字,我不知道正确的类型应该有什么。
有人可以帮忙吗?非常感激。
=================================================== =======
北京时间 9:01 PM 更新
我将更改集添加为“
<changeSet id="20180415081741-1" author="jhipster">
<sql dbms="mysql" endDelimiter="\nGO" splitStatements="true"
stripComments="true">ALTER TABLE `ability` ADD `abilities` json DEFAULT NULL</sql>
</changeSet>
然后我发出“./mvnw package -Pprod dockerfile:build”,这是另一个看似与休眠相关的异常:
2018-04-15 20:56:52.186 ERROR 23936 --- [ main] o.h.metamodel.internal.MetadataContext : HHH015007: Illegal argument on static metamodel field injection : com.james.app.domain.Ability_#abilities; expected type : org.hibernate.metamodel.internal.SingularAttributeImpl; encountered type : javax.persistence.metamodel.ListAttribute