使用Hibernate不会将分配映射键保存在数据库中



我试图做一个简单的例子,使用java.util.Map在Hibernate中创建一个Customer实体与Order实体的映射。

下面是我的Java类:

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在从数据库加载客户订单并填充映射时如何从实体中提取键。就是这样。

最新更新