7

有没有办法使用 id 而不是 POJO 对象来保持 LAZY 加载和反序列化对象。

我有 2 个类是通过多对多关系加入的。

像这样的东西

public class User {
    @Id
    @JsonProperty
    public long id;

    @ManyToMany(
            fetch = FetchType.EAGER,
    )
    @JoinTable(
            name = "User_EntityType",
            joinColumns = @JoinColumn(name = "user_id"),
            inverseJoinColumns = @JoinColumn(name = "type_id")
    )
    @JsonProperty
    public Set<Type> types;

}

public class Type {
    @Id
    @JsonProperty
    public long id;

    @ManyToMany(
            fetch = FetchType.EAGER,
            mappedBy = "types",
            targetEntity = User.class
    )
    @JsonProperty
    public Set<User> users;
}

数据类型工作得很好。我可以毫无问题地使用休眠进行读写。

但是,我希望能够返回一个带有 REST API 的用户对象,所以我使用 Jackson 来反序列化它。问题是当我这样做时,它会反序列化 User 对象中的每个 Type,其中包括其他 Type 对象,这会造成巨大的混乱。

是否可以只返回长类型 ID 集而不是类型集?

4

2 回答 2

4

是的,如果您使用的是带有 Object Identity 功能的 Jackson 2.0,这是可能的。

如果你用注解来注解一个类,@JsonIdentityInfo那么 Jackson 只会输出一次对象;后续引用将使用 ID。因此,只要类型已输出一次,您的类型集就会被序列化为 ID。当反序列化 Jackson 时,会将 ID 转回对象。

在您的情况下,我认为您需要像这样注释您的 Type 类:

@JsonIdentityInfo(generator=ObjectIdGenerators.PropertyGenerator.class, property="id")
public class Type {
    ...
}

有关如何使用此功能的详细信息,请参阅http://wiki.fasterxml.com/JacksonFeatureObjectIdentity 。

于 2012-10-17T03:37:54.310 回答
0

我在我的 JAX-RS 端点中也遇到了这个问题,它必须使用 Jackson 的对象映射器来序列化和服务 Hibernate 实体。使用类似@JsonIgnore@JsonIdentityInfo(generator=ObjectIdGenerators.PropertyGenerator.class,...不是我的解决方案的选项,因为前者意味着关系字段从序列化输出中被省略,而后一种方法无论如何都无法解决问题。

因此,我的解决方案是在执行实际序列化之前在映射器上设置以下标志:

ObjectMapper objMapper = new ObjectMapper();
objMapper.configure(SerializationFeature.FAIL_ON_EMPTY_BEANS, false);

这样,就没有尝试填充关系对象,而是它们的 id 保持不变,因此我可以将fetch = FetchType.LAZY标志保留在我的关系字段上。

于 2015-03-27T23:46:13.583 回答