hibernate单、双向N-N的问题

finemi 2015-04-26 08:15:35
比如 用户——帖子,用户可以收藏帖子,一个帖子可以被多个用户收藏,
那么在hibernate中,我本来想的是双向的N-N映射,只能通过连接表的形式,但是发现有几个问题:
1.无法设置用户id与帖子id的复合主键(一个用户只能收藏一个帖子一次)
2.无法添加其他列(比如收藏时间)

如果不用hibernate,那么我会建立一个favorite收藏表,上述两个问题就都不存在了。
那么在hibernate中,是否可以再添加一个favorite持久化类,作为用户与帖子之间的一个中间表,让收藏表相对于用户和帖子之间都是一对多的关系。 这样做之后我发现从对象的角度考虑,这个favorite类是完全没有意义的,仅仅是为了解决hibernate的这个问题,总感觉会有点怪异。

请问还有没有更好的解决方案,或者实际项目中一般是怎样做的?(最后30分了。。。我问题实在太多)
...全文
190 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
finemi 2015-05-05
  • 打赏
  • 举报
回复
引用 4 楼 finemi 的回复:
[quote=引用 2 楼 xiaopengaa 的回复:] 要添加其他列,可以做成两个一对多!
那如何设置复合主键?比如:User 和 Music, 中间是收藏实体Favorite,favorite对于User和Music分别都添加一对多关系。 favorite里面有2个属性,分别是:Set<User>和Set<Music>,User和Music里面分别设置自己的Favorite属性为多对一并且设置外键,那么如何使favorite表中的这两个外键为复合主键? 精简版代码:

public class User {
	@ManyToOne(targetEntity=Favorite.class)
	@JoinColumn(name="userId",nullable=false)
	private Favorite favorite;
//省略其他
}

public class Music {
	@ManyToOne(targetEntity=User.class)
	@JoinColumn(name="muiscId",nullable=false)
	private Favorite favorite;
//省略其他
}

public class Favorite {
	@OneToMany(targetEntity=User.class,mappedBy="favorite")
	private Set<User> users;

	@OneToMany(targetEntity=Music.class,mappedBy="favorite")
	private Set<Music> musics;
//省略其他
}

[/quote] 已经解决了,发现是映射翻了。应该是favorite是多的一方
  • 打赏
  • 举报
回复
关于复合主键注解配置 http://blog.csdn.net/happylee6688/article/details/17636801 如果实现这样的“一个用户只能收藏一个帖子一次”的需求,方法有很多,复合主键只是其中一种。 假如在技术上遇到难题,试着去想另外一种自己能实现的方法,能解决的先解决的,实在没办法再另打算。 这个难题我之前也遇到过,hibernate的多对多添加不了多余字段,所以我采用了我熟悉的一对多的方法,问题就迎刃而解了,在程序里做判断的用户是否重复收藏了帖子,复合主键也给我pass。 希望能帮到你!
风程序 2015-04-29
  • 打赏
  • 举报
回复
http://blog.csdn.net/w215230188/article/details/44967039 不谢
  • 打赏
  • 举报
回复
要添加其他列,可以做成两个一对多!
finemi 2015-04-29
  • 打赏
  • 举报
回复
引用 2 楼 xiaopengaa 的回复:
要添加其他列,可以做成两个一对多!
那如何设置复合主键?比如:User 和 Music, 中间是收藏实体Favorite,favorite对于User和Music分别都添加一对多关系。 favorite里面有2个属性,分别是:Set<User>和Set<Music>,User和Music里面分别设置自己的Favorite属性为多对一并且设置外键,那么如何使favorite表中的这两个外键为复合主键? 精简版代码:

public class User {
	@ManyToOne(targetEntity=Favorite.class)
	@JoinColumn(name="userId",nullable=false)
	private Favorite favorite;
//省略其他
}

public class Music {
	@ManyToOne(targetEntity=User.class)
	@JoinColumn(name="muiscId",nullable=false)
	private Favorite favorite;
//省略其他
}

public class Favorite {
	@OneToMany(targetEntity=User.class,mappedBy="favorite")
	private Set<User> users;

	@OneToMany(targetEntity=Music.class,mappedBy="favorite")
	private Set<Music> musics;
//省略其他
}

finemi 2015-04-28
  • 打赏
  • 举报
回复
这样做后发现也实现不了复合主键

67,512

社区成员

发帖
与我相关
我的任务
社区描述
J2EE只是Java企业应用。我们需要一个跨J2SE/WEB/EJB的微容器,保护我们的业务核心组件(中间件),以延续它的生命力,而不是依赖J2SE/J2EE版本。
社区管理员
  • Java EE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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