Используя Spring 3.2.1, я обнаружил, что значение по умолчаниюlushModeType = Auto вызывает проблемы, когда я пытаюсь работать с объектом перед его сохранением.
Я попробовал чтобы установить для параметраlushMode значение COMMIT, но всякий раз, когда это происходит за пределами метода @Transactional, он возвращается к AUTO.
Я попробовал установитьlushMode как env var и непосредственно в объектном менеджере, но это показывает то же самое поведение. Всякий раз, когда параметрlushMode устанавливается вне транзакции, он не имеет смысла.
entityManager.setFlushMode(FlushModeType.COMMIT);
System.out.println(entityManager.getFlushMode());
печатает «АВТО»
Обновлено: код вышел из режима автоматической очистки:< /p>
private void insertImageToDB(String imagePath, Map imageNameToMetaData, int numOfImages,
int currentImage) {
try {
ImageDB imageDB = new ImageDB();
imageDB.setGcsFullPath(imagePath);
imageDB.setStatus(PENDING);
setImageMetaData(imagePath, imageNameToMetaData, imageDB); //calling more setters in this method
imagesRepository.save(imageDB); //this clause causing extra persistence. I can solve it locally by removing this, but prefer to work with explicitly 'save()' action in order to under where and when I'm doing the commit.
logger.debug("processed {}/{} images", currentImage, numOfImages);
} catch (Exception e) {
logger.error("failed to save image {}", imagePath, e);
}
}
Подробнее здесь: https://stackoverflow.com/questions/792 ... figuration
Конфигурация режима гибернации ⇐ JAVA
Программисты JAVA общаются здесь
1735920634
Anonymous
Используя Spring 3.2.1, я обнаружил, что значение по умолчаниюlushModeType = Auto вызывает проблемы, когда я пытаюсь работать с объектом перед его сохранением.
Я попробовал чтобы установить для параметраlushMode значение COMMIT, но всякий раз, когда это происходит за пределами метода @Transactional, он возвращается к AUTO.
Я попробовал установитьlushMode как env var и непосредственно в объектном менеджере, но это показывает то же самое поведение. Всякий раз, когда параметрlushMode устанавливается вне транзакции, он не имеет смысла.
entityManager.setFlushMode(FlushModeType.COMMIT);
System.out.println(entityManager.getFlushMode());
печатает «АВТО»
[b]Обновлено[/b]: код вышел из режима автоматической очистки:< /p>
private void insertImageToDB(String imagePath, Map imageNameToMetaData, int numOfImages,
int currentImage) {
try {
ImageDB imageDB = new ImageDB();
imageDB.setGcsFullPath(imagePath);
imageDB.setStatus(PENDING);
setImageMetaData(imagePath, imageNameToMetaData, imageDB); //calling more setters in this method
imagesRepository.save(imageDB); //this clause causing extra persistence. I can solve it locally by removing this, but prefer to work with explicitly 'save()' action in order to under where and when I'm doing the commit.
logger.debug("processed {}/{} images", currentImage, numOfImages);
} catch (Exception e) {
logger.error("failed to save image {}", imagePath, e);
}
}
Подробнее здесь: [url]https://stackoverflow.com/questions/79275421/hibernate-flush-mode-configuration[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия