Hibernate4之多对多双向关联

[size=medium]在这里多对多关系@ManyToMany,默认是延迟加载的。[/size]

/**
* @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;
}

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值