что не очень хорошая практика :(). Может тут оперативно подскажут в чем я затупок.
Суть:
Вопросец скорее всего простенький, подскажите верный путь:
Spring data jpa.
Есть схема БД как на картинке (упрощенно): http://joxi.ru/EA4ZeK8ipPo5Vm
Нужно с помощью Spring Data Jpa создать двунаправленную связь между product и attribute_values.
Пробую так, в product:
@OneToMany(fetch = FetchType.EAGER, mappedBy = "productOffer")
@JoinColumn(name = "product_offer_id")
private Set<ProductOfferAttributeValueEntity> attributeValues;
В attribute_values:
@ManyToOne
@MapsId("productOfferId")
@JoinColumn(name = "product_offer_id")
private ProductOfferEntity productOffer;
P. S. MapsId указан т.к. составной ключ вынесен в EmbeddedId.
Получаю:
При обращении к attributeValues из product - Stackoverflow. Я понимаю, что я где-то зарекурсивил связь, но не понимаю где. Можете тыкнуть носом?
ManyToOne. default FetchType EAGER. У тебя A loads B -> B loads A из-за EAGER. ПРосто никогда не используй EAGER и всё.
спасибо большое за замечание. Учту ваш совет (в javastart тоже сказали про Lazy поля). В @javastart подсказали, что проблема была в equals и hashcode (была просто аннотация @Data от ломбока). Если кому-то будет интересно, здесь подробнее: https://t.me/javastart/271978
Обсуждают сегодня