休眠映射关联作为映射

时间:2018-09-20 13:19:14

标签: java hibernate persistence

我有一个MessengerData类,其中包含资源列表。这是我的对象MessengerData:

"messengerData":{  
   "fr":[  
    { 
      "messengerType":"ImageCategoryTitle",
      "imageURL":"https://assets.pernod-ricard.com/uk/media_images/test.jpg"
    }
    "EN":[
    {
      "messengerType":"ImageCategoryTitle",
      "imageURL":"https://assets.pernod-ricard.com/uk/media_images/test.jpg",
    }
]

这就是我定义对象MessengerData的方式:

@Entity
public class MessengerData
{

@Basic
@Id
@GeneratedValue(generator = "notification-system-uuid")
@GenericGenerator(name = "notification-system-uuid", strategy = "uuid")
private String messengerDataId;


@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER) /* , mappedBy = "idResource" */
@JoinTable(name = HemisTablesNames.MESSENGER_RESOURCES, joinColumns = @JoinColumn(name = "idResource"),
        inverseJoinColumns = @JoinColumn(name = "messengerDataId"))
private Map<String, Set<Resource>> resources;
}

但是我遇到了一个例外:使用@OneToMany或@ManyToMany定位未映射的类:com.ubiant.hemis.type.MessengerData.resources [java.util.Set]

有人可以帮我吗?

1 个答案:

答案 0 :(得分:1)

Hibernate似乎不直接支持多地图(resources就是这样),但是您可以提供自己的自定义类型,如此处所述:https://xebia.com/blog/mapping-multimaps-with-hibernate/

但是,由于无论如何您的数据似乎都是Json,您可以再走一步,直接将资源映射为json,即映射到text列(如果db支持,则映射到json列):http://fabriziofortino.github.io/articles/hibernate-json-usertype/ < / p>

我们正在做类似的事情,在轮廓上看起来像这样(这是一个通用类型,在大多数情况下,更具体的POJO会更好):

 class JsonData extends HashMap<String, Object> { ... }

 //JsonbUserType is a custom implementation based on code like the one linked above
 class JsonDataUT extends JsonbUserType<JsonData > { ... }

然后在用户类型所在的软件包的package-info.java中,我们有以下内容:

@TypeDefs ( {    
  @TypeDef ( name = "JsonDataUT ", typeClass = JsonDataUT.class, defaultForType = JsonData.class ),
  ... 
})
package our.package;

然后我们的实体只包含以下内容:

@Column( name = "data_column")
private JsonData data;

这样做的一个优点是,我们不必费心处理更复杂的映射,尤其是在类型是动态的情况下。

一个(主要)缺点是,您不能在查询条件中使用该属性,因为Hibernate不知道如何在json列中进行过滤(我们使用的是Postgres,因此它实际上是jsonb类型的列,因此是用户类型名称)和afaik,没有合理的方法来提供自定义函数等以启用HQL中的where data.someFlag is true之类的功能。