我试图做一个简单的例子,使用java.util.Map
在Hibernate中创建一个Customer
实体与Order
实体的映射。
Customer.java
:
@Entity
public class Customer {
@Id
@GeneratedValue
private Integer id;
@OneToMany(mappedBy = "customer")
@MapKey(name = "orderNumber")
private Map<String, Order> orders = new HashMap<String, Order>();;
}
Order.java
@Entity
@Table(name="TB_ORDER")
public class Order {
@Id
@GeneratedValue
private Integer id;
private String orderNumber;
@ManyToOne
private Customer customer;
}
现在我已经创建了一个程序来保存客户和订单:
public class AppTest {
public static void main(String[] args) {
Session session = HibernateUtil.getSessionFactory().getCurrentSession();
saveCustomer(session);
HibernateUtil.getSessionFactory().close();
}
private static void saveCustomer(Session session) {
session.getTransaction().begin();
Customer customer = new Customer();
Order order = new Order();
order.setCustomer(customer);
//order.setOrderNumber("100");
Map<String, Order> map = new HashMap();
map.put("100", order);
customer.setOrders(map);
session.save(customer);
session.save(order);
session.getTransaction().commit();
}
}
根据我的映射,Map的键表示Order类的orderNumber属性。因此,当我创建了一个键为"100"的映射并尝试使用Hibernate保存时,该字段在TB_ORDER表的数据库中被设置为空。但是,如果我尝试使用order.setOrderNumber("100"),那么该值将被保存到数据库。请告诉我哪里做错了?
你没有做错任何事。在内存中保持对象图的一致性是你的责任。映射到数据库中该列的是Order实体的orderNumber
字段。因此,如果它是null, Hibernate在列中保存null。
MapKey
注释告诉Hibernate在从数据库加载客户订单并填充映射时如何从实体中提取键。就是这样。