169 похожих чатов

Не знаете , как можно проверить почему при инсерте в

бд ( используется jpa) вызывается непонятный селект ?
То есть есть связать один к одному и дочерняя сторона только знает родительскую . Когда я создаю новый объект и записываю его в бд через merge , то он перед этим вызывает селект , в котором подтягивает родителя , но ещё дополнительно в этом селекте присутствуют параметры из таблицы , где он связан один к многим. Смущает то , что таких таблиц много и они настроены все одинокого , но он подбирает данные за собой именно с одной таблицы(один ко многим) и не понимаю , как отследить в каком месте кода он это делает .
Вообще , jpa мне кажется много лишнего делает.
Вопрос в том , как продебажить и найти момент запроса в коде , чтобы посмотреть почему он тянет лишнее ?

8 ответов

11 просмотров

1) вообще ты можешь просто в дебаггере построчно гонять свой код и смотреть, когда в логе это появится 2) добро пожаловать в сладкий мир хибернейта, хех

Yatakrad- Автор вопроса
Denis Chikanov
1) вообще ты можешь просто в дебаггере построчно г...

Хмм, странно . Убрал у дочерней сущности cascadeType.MERGE где стояла аннотация @mapsId (на родителе) и в этом селекте ушли эти джойны лишней таблицы 😁. Не понял как это связано конечно..

Denis Chikanov
1) вообще ты можешь просто в дебаггере построчно г...

А какие есть продакшен варианты, когда полей много, и пара десятков связанных таблиц? jOOQ / MyBatis?

Потому orm работают с объектами, чтобы внести изменения они должны прогрузить текущую модель.

Denis Chikanov
1) вообще ты можешь просто в дебаггере построчно г...

А что мешает использовать хибирнейт для нативных?))

Дмитрий Баевский
JPA умеет в них так-то

Jpa не умеет, умеет хибер под капотом. А аннотация Query(native=true) не позволяет генерировать сложные вставки

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта