问题是使用 Hibernate 保留以下类。
Public class Album{
Private int albumid;
Private String aname;
Private Map<String,List<String>> photos;
}
我试过这个
@Entity
public class Album {
@Id
private int albumId;
@Column(name= "Album_Name")
private String aname;
@ElementCollection
@MapKeyColumn(name= "Event_Name")
@Column(name="Values")
private Map<String, List<String>> photos;
但它显示错误,例如
Exception in thread "main" org.hibernate.MappingException: Could not determine type for: java.util.List, at table: Album_photos, for columns: [org.hibernate.mapping.Column(Values)]
at org.hibernate.mapping.SimpleValue.getType(SimpleValue.java:336)
at org.hibernate.mapping.SimpleValue.isValid(SimpleValue.java:310)
at org.hibernate.mapping.Collection.validate(Collection.java:315)
at org.hibernate.mapping.IndexedCollection.validate(IndexedCollection.java:89)
at org.hibernate.cfg.Configuration.validate(Configuration.java:1362)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1849)
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1928)
at com.wipro.Insert.main(Insert.java:17)
此映射在 Hibernate ORM 中不起作用。
原因是您正在尝试拥有两个嵌套的元素集合,而 Hibernate ORM 不支持此功能(第一个集合是 the Map
,第二个集合是 the List
)。
您必须使用实体。
您可以通过@ElementCollection
以下映射获得类似于的内容:
@Entity
public static class PhotoEvent {
@Id
@Column(name = "Event_Name")
public String eventName;
@ElementCollection
@Column(name = "`Values`")
public List<String> values;
@ManyToOne
public Album album;
...
// getter/setter/hascode/equals...
}
@Entity
public static class Album {
...
@OneToMany(mappedBy = "album", fetch = FetchType.EAGER, cascade = CascadeType.ALL, orphanRemoval = true)
@MapKey(name = "eventName")
public Map<String, PhotoEvent> photoEvents;
...
}
请注意,我设置FetchType.EAGER
是因为它模拟了一个,@ElementCollection
但您可能希望将其设置为LAZY
(默认值)。
您将在 Hibernate ORM 文档中找到有关此类映射的更多详细信息。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句