hibernate单、双向N-N的问题

J2EE 码拜 10年前 (2015-05-10) 840次浏览 0个评论
 

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

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

请问还有没有更好的解决方案,或者实际项目中一般是怎样做的?(最后30分了。。。我问题实在太多)

这样做后发现也实现不了复合主键
10分
要添加其他列,可以做成两个一对多!
http://blog.csdn.net/w215230188/article/details/44967039 不谢
引用 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;
//省略其他
}

20分
关于复合主键注解配置  http://blog.csdn.net/happylee6688/article/details/17636801 
如果实现这样的“一个用户只能收藏一个帖子一次”的需求,方法有很多,复合主键只是其中一种。
假如在技术上遇到难题,试着去想另外一种自己能实现的方法,能解决的先解决的,实在没办法再另打算。
这个难题我之前也遇到过,hibernate的多对多添加不了多余字段,所以我采用了我熟悉的一对多的方法,问题就迎刃而解了,在程序里做判断的用户是否重复收藏了帖子,复合主键也给我pass。
希望能帮到你!
引用 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;
//省略其他
}

已经解决了,发现是映射翻了。应该是favorite是多的一方


CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明hibernate单、双向N-N的问题
喜欢 (0)
[1034331897@qq.com]
分享 (0)

文章评论已关闭!