Я использую Spring с Hibernate в качестве поставщика JPA и пытаюсь получить @OneToMany (контакт, имеющий много телефонных номеров), чтобы сохранить внешний ключ в таблице телефонных номеров. Из моей формы я получаю контактный объект, в котором есть список номеров телефонов. Контакт сохраняется правильно (Hibernate выбирает PK из указанной последовательности). Список телефонов (номеров) также сохраняется с правильным PK, но нет FK в таблице контактов.
public class Contact implements Serializable {
@OneToMany(mappedBy = "contactId", cascade = CascadeType.ALL, fetch=FetchType.EAGER)
private List<Phone> phoneList;
}
public class Phone implements Serializable {
@JoinColumn(name = "contact_id", referencedColumnName = "contact_id")
@ManyToOne
private Contact contactId;
}
@Repository("contactDao")
@Transactional(readOnly = true)
public class ContactDaoImpl implements ContactDao {
@Transactional(readOnly = false, propagation = Propagation.REQUIRES_NEW)
public void save(Contact c) {
em.persist(c);
em.flush();
}
}
@Controller
public class ContactController {
@RequestMapping(value = "/contact/new", method = RequestMethod.POST)
public ModelAndView newContact(Contact c) {
ModelAndView mv = new ModelAndView("contactForm");
contactDao.save(c);
mv.addObject("contact", c);
return mv;
}
}
Надеюсь, я получил все соответствующие биты выше, в противном случае, пожалуйста, дайте мне знать.