清算基础异常未知数据类型&json;

liquibase exception unknown data type quot;JSONquot;(清算基础异常未知数据类型json;)
本文介绍了清算基础异常未知数据类型&json;的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我的应用程序使用的是带有MySQL和Liqubase的jhister,MySQL版本是5.7.20,支持json列,我使用ObjectMapper来映射json列和Java对象,可以用,列类型是json,但是当涉及到Liquibase(./mvnw包-Pprod dockerfile:Build)时,会出现"未知数据类型‘JSON’"的异常,测试失败,不会生成docker镜像。

我在20180410012441_Add_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列/类型定义有关,Liqubase不支持json关键字,我不知道应该有什么才是正确的类型。

请帮帮忙好吗?非常感谢。

========================================================= 更新:北京时间晚上9:01 我将changeSet添加为"

<changeSet id="20180415081741-1" author="jhipster">
  <sql dbms="mysql" endDelimiter="
GO" splitStatements="true"
     stripComments="true">ALTER TABLE `ability` ADD `abilities` json DEFAULT NULL</sql>
</changeSet>

然后我发出"./mvnw Package-Pprod dockerfile:Build",另一个似乎与Hibernate相关的异常:

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

推荐答案

将液碱柱类型更改为jsonb,然后尝试。

<column name="abilities" type="jsonb">
        <constraints nullable="true"/>
</column>

将类型和列定义添加为jsonb

@Type(type = "jsonb")
@Column(columnDefinition = "jsonb")
private List<Skill> abilities = new ArrayList<>();

这篇关于清算基础异常未知数据类型&json;的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)
SQL/MySQL: split a quantity value into multiple rows by date(SQL/MySQL:按日期将数量值拆分为多行)