hibernate集合映射的问题

veilme 2014-03-10 02:27:09
使用hibernate4注解的形式.

我现在有一个附件表,表中存有图片位置,链接,文档位置等信息.对应实体 Link.class

现在我又有一个对象, 里面包含两个属性,分别是一个一对一的映射,和一个一对多的映射,指向这个附件表.这时候我可以用一个@OneToOne,和一个@OneToMany来映射.
1. @OneToOne(targetEntity=Link.class , cascade={CascadeType.ALL}
2. @OneToMany(targetEntity=Link.class , cascade={CascadeType.ALL} , fetch = FetchType.EAGER , orphanRemoval = true)
@Fetch(FetchMode.SUBSELECT)
@ JoinTable (name = "LINK_REF",joinColumns=@JoinColumn(name="ID1"),inverseJoinColumns=@JoinColumn(name = "ID2"))

但是.一方面,我想数据库美观,第二,我想知道这个附件到底有没有其它对象在引用.所以我想将一对一的映射也表现在这个中间表中.
则将上面的一对一映射改为
@OneToOne(targetEntity=Link.class , cascade={CascadeType.ALL}
@ JoinTable (name = "LINK_REF",joinColumns=@JoinColumn(name="ID1"),inverseJoinColumns=@JoinColumn(name = "ID2"))

现在问题出来了.
由于@JoinTable使用主键作为关键,显然.我这个一对一和一对多的两个映射在一个对象中, 也就是主键是一样的,当查询时就出现的混乱.这时候我就需要中间表映射不使用主键,而是另外自动创建一个字段来完成映射 , 另外我想在这个中间表中,加一个字段,表明这个映射是由哪一个类中映射过来的.

查了好多资料,都没有完成.(国内用不了Google蛋疼)





...全文
328 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
缥缈寒123 2014-03-20
  • 打赏
  • 举报
回复
用香港的谷歌不行吗?
veilme 2014-03-12
  • 打赏
  • 举报
回复
@ JoinTable (name="表名" , joinColumns=@JoinColumn(name="ID1" , inferencedColumName="关联字段") 如果inferencedColumnName可以关联到一个非主键的字段. 那么这个问题就可以解决了. 但是,不知道为什么. 现在hibernate4 , 将这个字段设置为非主键字段时, 会报出 "SecondaryTable JoinColumn cannot reference a non primary key" 错误. JPA中并没有这个限制.不知道Hibernate小组是什么用意 , 有没有其它办法解决呢?

25,985

社区成员

发帖
与我相关
我的任务
社区描述
高性能WEB开发
社区管理员
  • 高性能WEB开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧