Форум программистов, компьютерный форум, киберфорум
Java EE (J2EE)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
1 / 1 / 0
Регистрация: 10.08.2014
Сообщений: 97

Java Hibernate MySQL долго обновляет 30т. строк, как ускорить?

03.09.2019, 23:06. Показов 2060. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
MySQL, нужно обновить в таблице 30 000 строк, сейчас это занимает примерно 30 минут, а это очень долго.

Вот код

Java
1
2
3
4
5
6
7
public <T> void update(List<T> updateDBList) {
    for (T el : updateDBList) {
        em.getTransaction().begin();
        em.merge(el);
        em.getTransaction().commit();
    }
}
Как мне ускорить этот процесс??? 30 000 строк это очень мало возможно скоро их будет 1млн.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
03.09.2019, 23:06
Ответы с готовыми решениями:

Java+MySQL+Spring+Hibernate tutorials
Добрый день, уважаемое сообщество программистов. Я новичок в Java. Сейчас есть необходимость изучить работу с БД, а именно с MySQL. Есть...

Word долго обновляет связи с Excel
Нужно, чтобы Word 2010 автоматически обновлял связи (неформатированный текст) с ячейками Excel 2010, но заметил, что чем больше...

Hibernate - как работать с mysql представлениями ?
Доброго времени! В Hibernate понятно как работать с объектами базы - идет как обычная таблица с отражением имя переменной = имя...

3
Эксперт Java
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
04.09.2019, 00:45
Лучший ответ Сообщение было отмечено 040985 как решение

Решение

https://vladmihalcea.com/how-t... hibernate/
0
1 / 1 / 0
Регистрация: 10.08.2014
Сообщений: 97
24.09.2019, 16:04  [ТС]
Проблему решил следующим способом:
1. В файл persistence.xml добавил строчку

Java
1
<property name="hibernate.jdbc.batch_size" value="50"/>
2. Метод сделал так

Java
1
2
3
4
5
6
7
8
9
10
11
public <T> void add(List<T> addDBList) {
    em.getTransaction().begin();
    for (int i = 0; i < addDBList.size(); i++) {
        em.merge(addDBList.get(i));
        if (i % 50 == 0) {
            em.flush();
            em.clear();
        }
    }
    em.getTransaction().commit();
}
После этих манипуляций скорость увеличилась раз в 10-20
0
25 / 21 / 6
Регистрация: 10.12.2018
Сообщений: 115
29.09.2019, 22:12
пост выше, короче пакетная обработка данных в хайбирнете....

Добавлено через 15 секунд
загугли почитай
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.09.2019, 22:12
Помогаю со студенческими работами здесь

Как ускорить выборку из базы данных MySQL?
Сам запрос работает нормально, а вот функция которая записывает данные в двумерный массив тормозит. Вот код: function getAllUsers(){ ...

Hibernate 4 настройка(долго работает)
При сохранение объекта с помощью хибернета объект долго сохраняется.(движок таблицы archive) Почему оно так долго создает транзакцию? ...

Java-IDEA-Hibernate как это настроить?
Здравствуйте. Впервые столкнулся с тем, что не могу изучить фреймворк всвязи с тем, что элементарно не получается установить его и...

Код работает долго, нужно ускорить
Программа считает, сколько в среднем времени занимает процедура. На 1 000 итераций и массиве в 1 000 000 элементов работает слишком долго....

Java Hibernate: как записать в базу промежуточные изменения?
Java Hibernate Сначала вывожу ФИО пользователей (сущность User). Затем меняю имя пользователя Maxim на Bill. Снова вывожу ФИО...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru