Форум программистов, компьютерный форум, киберфорум
Java: Spring, Spring Boot
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
0 / 0 / 0
Регистрация: 13.05.2019
Сообщений: 7

Spring Проблема с lazy загрузкой

09.01.2021, 15:33. Показов 2239. Ответов 3

Студворк — интернет-сервис помощи студентам
Я в spring не силен, поэтому прошу не ругаться
Есть следующие классы:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
@Entity
public class User {
 
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int id;
    @Column(unique = true)
    private String name;
    private String pass;
    private String email;
    private String token;
    @OneToMany(cascade = CascadeType.ALL, fetch = EAGER, mappedBy = "user")
    private List<Wallet> wallets;
    @OneToMany(cascade = CascadeType.ALL, fetch = LAZY, mappedBy = "sender")
    private List<Message> sent;
    @OneToMany(cascade = CascadeType.ALL, fetch = LAZY, mappedBy = "receiver")
    private List<Message> received;
 
    public User() {
        super();
    }
 
    public User(String name, String pass, String email) {
        super();
        this.name = name;
        this.pass = pass;
        this.email = email;
    }
 
    //геттеры сеттеры equals hashcode toString...
}
 
@Entity
public class Wallet {
 
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private int id;
    @ManyToOne(fetch = FetchType.LAZY)
    private User user;
    @ManyToOne(optional = false, fetch = EAGER)
    private Coin coin;
    private double amount = 0;
    @OneToMany(mappedBy = "wallet", fetch = EAGER, cascade = CascadeType.ALL)
    private List<Transaction> transaction;
    private String code;
 
    public Wallet() {
        super();
    }
 
    public Wallet(User user, Coin coin, String code) {
        super();
        this.user = user;
        this.coin = coin;
        this.code = code;
    }
    //геттеры сеттеры equals hashcode toString...
}
 
@Entity
public class Transaction {
    @Id
    private int id;
    @ManyToOne(fetch = FetchType.LAZY)
    private Wallet wallet;
    private String info;
    private Date date;
    private Time time;
    private double sum;
 
    public Transaction() {
        super();
    }
 
    public Transaction(Wallet wallet, String info, double sum) {
        super();
        this.wallet = wallet;
        this.info = info;
        this.sum = sum;
        date = Date.valueOf(LocalDate.now());
        time = Time.valueOf(LocalTime.now());
    }
 
    //геттеры сеттеры equals hashcode toString...
}
Контроллер:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@RestController
@RequestMapping(path = "/users")
public class UserController {
 
    private UserRepository userRepository;
 
    @Autowired
    public UserController(UserRepository userRepository) {
        this.userRepository = userRepository;
    }
 
    @RequestMapping(method = RequestMethod.GET, value = "/")
    public List<User> findAllUsers(){
        List<User> users = userRepository.findAll();
        return users;
    }
//...
}
Мне необходимо получить список пользователей и список их кошельков со всеми транзакциями но без сообщений. Если в свойствах прописать spring.jpa.open-in-view=false то на выводе получаю There was an unexpected error (type=Internal Server Error, status=500) и в консоль could not initialize proxy - no Session; nested exception is com.fasterxml.jackson.databind.JsonMappi ngException: failed to lazily initialize a...
Если оставить true, то вне зависимости от FetchType загрузка будет жадной, и будет переполнение стэка (потому что юзер ссылается на кошелек, кошелек ссылается на юзера и на транзакции, которые опять же ссылаются на кошелек).
Если убрать mappedBy, то придется усложнять систему добавлением контроллеров и лишних запросов, на клиенте тоже придется перелопачивать, поэтому хотелось бы выполнить задачу в рамках одного запроса.

На скрине результат запроса до того, как покинет метод контроллера:
Миниатюры
Spring Проблема с lazy загрузкой  
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.01.2021, 15:33
Ответы с готовыми решениями:

Проблема с загрузкой ХР
Доброго времени суток, господа! Подскажите, пожалуйста, в чем может быть проблема. Исходные данные: был куплен и собран новый...

Проблема с загрузкой
Изначально стояла семерка - был диск C(вин7), D, и пустой раздел Поставил Ubuntu - диск C(win7), G(ubuntu), D, и пустой раздел. Захотел...

Проблема с загрузкой DS
Нужно обращаться к переменным по адресу ds:, например и т.д, но не могу никак установить ds на тот сегмент, где выполняется прога (0040h)....

3
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
09.01.2021, 16:49
В Гугл пиши vlad mihalcea one to many и смотри, как надо делать
0
0 / 0 / 0
Регистрация: 13.05.2019
Сообщений: 7
10.01.2021, 17:04  [ТС]
Статью прочитал, в принципе у меня так и было реализовано за исключением пары методов, но после их добавления ничего не изменилось. Тем не менее, в статье есть следующая фраза
There are several things to note on the aforementioned mapping:
The @ManyToOne association uses FetchType.LAZY because, otherwise, we’d fall back to EAGER fetching which is bad for performance....
, и вот именно с этим пунктом у меня проблемы, ведь несмотря на прописанный fetch, загрузка все равно жадная.
0
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
10.01.2021, 20:58
а нафига ты вообще из контроллера отдаешь entity? создай дто.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.01.2021, 20:58
Помогаю со студенческими работами здесь

Проблема с загрузкой ЦП
Всем доброго времени суток! Столкнулся с проблемой, которую не смог сам решить! Вот характеристики машины: ОС: ...

ПРОБЛЕМА С ЗАГРУЗКОЙ
ПРИВЕТ ВСЕМ!!! ПОМОГИТЕ РАЗОБРАТЬСЯ С ЗАПУСКОМ КОМПА.ПРИ ВКЛЮЧЕНИИ ВЫДАЁТ СООБЩЕНИЕ ( ЭНЕРГОСБЕРЕГАЮЩИЙ РЕЖИМ) И НИКАКИХ БОЛЬШЕ...

Проблема с загрузкой пк
Здравствуйте, такая проблема. Недавно решил переустановить Windows, с 7 (пиратки) на 7 (пиратку), просто были проблемы с подлинностью....

Проблема с загрузкой ОС
Купил переходник DVD&gt;HDD. В сам ноутбук установил ssd на неё установил 10 винду, а в переходник поставил hdd. При включении грузится то,...

Проблема с загрузкой
Здравствуйте поставил новую винду Windows XP SP 2 версия 5.1 сборка 2600.xpsp_sp2 и при пере загрузке компа материнская плата ASUS...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru