Hibernate4之多对多双向关联

在这里多对多关系@ManyToMany ,默认是延迟加载的。
/**
 * @author Chou
 * @since 2012-8-8
 * ...订单实体(多对多关系维护方)
 *
 */

@Entity
@Table(name = "TAB_ORDER")
@SequenceGenerator(name = "seq", sequenceName = "SEQ_ORDER", allocationSize = 1)
public class Order {
	private Long id;
	private String orderno;
	private Double money;
	private Set<Item> items = new HashSet<Item>();
	
	@Id
	@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq")
	public Long getId() {
		return id;
	}

	......
	
	@ManyToMany(fetch = FetchType.EAGER)
	@JoinTable(
		name = "TAB_ORDER_ITEM",
		joinColumns = {@JoinColumn(name = "ORDERID", nullable = false) },
		inverseJoinColumns = {@JoinColumn(name = "ITEMID", nullable = false)}
	)
	public Set<Item> getItems() {
		return items;
	}

	public void setItems(Set<Item> items) {
		this.items = items;
	}
}


/**
 * @author Chou
 * @since 2012-8-8
 * ...商品实体(多对多关联)
 *
 */

@Entity
@Table(name = "TAB_ITEM")
@SequenceGenerator(name = "seq", sequenceName = "SEQ_ITEM", allocationSize = 1)
public class Item {
	private Long id;
	private String itemNo;
	private String itemName;
	private Set<Order> orders = new HashSet<Order>();
	
	@Id
	@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "seq")
	public Long getId() {
		return id;
	}
	
	......

	@ManyToMany(mappedBy = "items", fetch = FetchType.EAGER)
	public Set<Order> getOrders() {
		return orders;
	}

	public void setOrders(Set<Order> orders) {
		this.orders = orders;
	}
	
}

转载于:https://my.oschina.net/easyean/blog/535134

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值