hibernate中的many-to-many问题

//此为一个News类
@SuppressWarnings("deprecation")
@Entity
@Indexed(index="News")
public class News implements Serializable{
    private Set<User> users=new HashSet<User>();

@ManyToMany(cascade = CascadeType.PERSIST, fetch = FetchType.EAGER, mappedBy="news")
	public Set<User> getUser() {
		return users;
	}
	public void setUser(Set<User> user) {
		this.users = users;
	}
}

//此为一个User类
@Entity
@Table(name = "user")
public class User implements Serializable{
   private Set<News> news = new HashSet<News>();
   @ManyToMany(cascade=CascadeType.ALL, fetch=FetchType.EAGER)
	@JoinTable(name = "User_News",   
		joinColumns ={@JoinColumn(name = "user_ID", referencedColumnName = "id") },   
		inverseJoinColumns ={@JoinColumn(name = "news_ID", referencedColumnName = "id") } 
	)  
	public Set<News> getNews() {
		return news;
	}
	public void setNews(Set<News> news) {
		this.news = news;
	}
	public void addTargetNews(News news) {
		this.news.add(news);
	}
}


News类和User类为多对多关系,这里需要注意两点:1、注意News类中<span style="font-family: Arial, Helvetica, sans-serif;">mappedBy,拥有这个字段的类为被控类,被控类中的数据删除受到主控类的限制,若主控类中还有被控类中数据的引用,则被控类中的数据不能被删除;2、User类中的JoinTable为主控类所有,代表多对多关系的一个独立的表,name为表名,joinColumns代表此此类在表中的关系,name为此类对应表的字段名,referencedColumnName代表本类的主键名,同理inverseJoinColumns为表的另一端的关系,即News方。</span><pre name="code" class="java">
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值