首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >@Enumerated(EnumType.STRING)丢失,@AttributeOverride

@Enumerated(EnumType.STRING)丢失,@AttributeOverride
EN

Stack Overflow用户
提问于 2019-05-17 22:23:39
回答 1查看 347关注 0票数 0

我需要在@Embeddable对象上使用@AttributeOverride,以防止同一复杂类型的两个属性的列名发生冲突。

但是,在执行此操作时,我还会丢失/覆盖@Embedded ExternalLink对象的networkId属性的@Enumerated注释。

最后,表的列link_network的类型是integer,而不是varyingchar(255)

如何配置@AttributeOverride以保留@Enumerated配置?

以下是我的方案:

代码语言:javascript
复制
@Embeddable
public class Address {

    @Embedded
    @AttributeOverrides({
        @AttributeOverride(name="network", column=@Column(name="link_network")),
        @AttributeOverride(name="networkAddress", column=@Column(name="link_network_address")),
        @AttributeOverride(name="element", column=@Column(name="link_element"))
    })
    private ExternalLink link;

    @Embedded
    @AttributeOverrides({
        @AttributeOverride(name="network", column=@Column(name="before_network")),
        @AttributeOverride(name="networkAddress", column=@Column(name="before_network_address")),
        @AttributeOverride(name="element", column=@Column(name="before_element"))
    })
    private ExternalLink before;
}

@Embeddable
public class ExternalLink {

    @Enumerated(EnumType.STRING)
    private NetworkId network;
    private String networkAddress;
    private String element;
}
EN

回答 1

Stack Overflow用户

发布于 2020-06-09 06:44:54

我所知道的唯一方法是转换,它将NetworkId映射到String (varchar)

代码语言:javascript
复制
@Converter(autoApply = true)
public class NetworkIdConverter implements AttributeConverter<NetworkId , String> {

    @Override
    public String convertToDatabaseColumn(NetworkId attribute) {
        if (attribute == null) {
            return null;
        }
        return attribute.name();
    }

    @Override
    public NetworkId convertToEntityAttribute(String dbData) {
        if (dbData == null) {
            return null;
        }
        return NetworkId.valueOf(dbData);
    }
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56188404

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档