我有一个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]
有人可以帮我吗?
答案 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
之类的功能。