Форум программистов, компьютерный форум, киберфорум
Java: Базы данных
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/15: Рейтинг темы: голосов - 15, средняя оценка - 4.53
16 / 0 / 2
Регистрация: 10.11.2012
Сообщений: 117
1

Fetch size and batch size в запросах sql

25.07.2018, 23:34. Показов 3016. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день!

Вопрос вот какой, я выполняю batch insert из одной таблицы в другую таблицу через java. Использую preparedStatement. Resultset forward only. Объемы большие.

Собственно в чем сам вопрос:
1. Можно выставить fetchsize - количество забираемых строк за раз из бд. Правильно ли я понимаю, что после выполнения метода next(), если потребуется, то именно в этот момент resultset загрузит в память jvm указанное мною число строк?

2. Загрузку в конечную витрину я осуществляю пачками, схематично:
Java
1
2
3
4
5
6
while(src_rs.next())
{
 // ...
  addBatch...
  if(rowcnt % batchsize) executeBatch()
}
Прав ли я в том, что оптимум такой загрузки будет когда fetchsize и batchsize равны?

При выполнении executeBatch(), GC удаляет данные, которые были загруженны в resultset из источника и переданны в addBatch? Или данные в resultset остаются пока я сам не сделаю finalise?

Заранее спасибо за помощь и терпения. Я только начал изучать яву.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.07.2018, 23:34
Ответы с готовыми решениями:

Ошибка: firebird Size Mismatch - Field GROUP size is too small for data
Возникла проблема, пишет Size Mismatch - Field FULL_ADR size is too small for data ошибку, которой...

error ROM file size does not match existing BIOS size
Добрый день! Так же Foxconn H61MX, пробовал прошить через программу FOX LiveUpdate указывая путь...

Заполнить квадратную матрицу змейкой по диагонали, начиная с элемента matrix[size-1][size-1]
Требуется написать программу, которая заполняет массив размерности n*n по заданному правилу: ...

Size suffix and destination or source size do not match
Добрый день, возникла проблема. Говорю сразу в ассемблере ничего не понимаю, в гугле нашел только...

2
Эксперт PythonЭксперт Java
19511 / 11051 / 2931
Регистрация: 21.10.2017
Сообщений: 23,301
26.07.2018, 09:51 2
krazyd, в java в операторе if условие обязательно boolean, вот это выражение
Java
1
if(rowcnt % batchsize)
некорректно, нужно что-то типа
Java
1
if(rowcnt % batchsize != 0)...
0
Эксперт Java
 Аватар для turbanoff
4093 / 3827 / 745
Регистрация: 18.05.2010
Сообщений: 9,331
Записей в блоге: 11
27.07.2018, 01:03 3
1. Да, правильно. Во всяком случае, так задумывалось. Хотя на самом деле зависит от имплементации jdbc драйвера. Вы каким пользуетесь (с какой СУБД работаете)?
2.
Прав ли я в том, что оптимум такой загрузки будет когда fetchsize и batchsize равны?
Это сложно сказать. Тут без замеров никуда, если вам нужна top performance. Обычно, просто выставление этих параметров в разумные значение уже даёт приемлемый результат.
Цитата Сообщение от krazyd Посмотреть сообщение
Или данные в resultset остаются пока я сам не сделаю finalise?
Это зависит от имплементации драйвера. По идее, если у вас forward only, то освобождать данные из ResultSet теоретически можно уже после вызова next().
0
27.07.2018, 01:03
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
27.07.2018, 01:03
Помогаю со студенческими работами здесь

Что означает запись типа template<typename _Ty, size_t size> void foo(_Ty(&param)[size])?
Что означает такая запись(какой тип передается, что-то вроде ссылки на массив или что-нибудь ещё?):...

Runtime size и ROM size
Добрый вечер, форумчане! Не помогает ни переводчик, ни гугл.. Что обозначает 1)Runtime Size и...

#1118 - Row size too large. The maximum row size for the used table type, not counting BLOBs, is 8126. You have to change some columns to TEXT or BLOB
При внесении данных в БД возникла ошибка.Ни как не могу заполнить таблицу. Помогите пожалуйста!

Резиновый font-size, Как сделать резионвый font-size в блоке?
&lt;HTML&gt; &lt;HEAD&gt;test&lt;/HEAD&gt; &lt;BODY&gt; &lt;style&gt; .test { width: 20%; height: 9%; position: absolute;...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Откуда у float лишние цифры в конце дробной части. Представление чисел с плавающей точкой
bytestream 25.01.2025
При разработке программного обеспечения часто возникает необходимость работать с вещественными числами, которые содержат дробную часть. В современных компьютерных системах такие числа представляются. . .
Как использовать глобальную переменную в функции в Python
bytestream 25.01.2025
В программировании на Python глобальные переменные представляют собой особый тип переменных, которые доступны для использования во всех частях программы, включая различные функции, классы и модули. . . .
Как в цикле обойти все элементы map в Java
bytestream 25.01.2025
В разработке на Java одной из наиболее востребованных структур данных является интерфейс Map, который предоставляет эффективный способ хранения и управления парами "ключ-значение". Разработчики. . .
Для чего нужен UserManager.isU­serAGoat(­) в Android и как это использовать
bytestream 25.01.2025
В мире Android-разработки существует множество интересных и порой загадочных функций, о которых знают далеко не все разработчики. Одной из таких функций является метод UserManager. isUserAGoat(),. . .
Как обойти масси в JavaScript. Всё о циклах
bytestream 25.01.2025
JavaScript представляет собой мощный язык программирования, широко используемый в веб-разработке, где массивы и циклы являются фундаментальными концепциями для эффективной работы с данными. Массив в. . .
Как сделать, чтобы существующая ветка отслеживала удалённую в Git. Связывание локальных и удалённых веток
bytestream 25.01.2025
В разработке программного обеспечения системы контроля версий стали неотъемлемой частью процесса создания качественного программного продукта. Эти инструменты позволяют разработчикам эффективно. . .
Как проверить, что файл НЕ существует с помощью Bash
bytestream 25.01.2025
В системном администрировании проверка существования файлов является фундаментальной операцией, особенно при написании скриптов на Bash. Правильная обработка ситуаций, когда файл отсутствует,. . .
Как проверить, что строка пустая, неопределена или null в JavaScript
bytestream 25.01.2025
При разработке веб-приложений на JavaScript разработчики регулярно сталкиваются с необходимостью проверки строковых значений на различные состояния. Валидация данных является критически важным. . .
Как проверить существование ключа в объекте или массиве в JavaScript
bytestream 25.01.2025
При разработке веб-приложений на JavaScript программисты постоянно сталкиваются с необходимостью работать с объектами и массивами. Эти структуры данных являются фундаментальными элементами языка и. . .
Как создать ArrayList из массива (array) в Java
bytestream 25.01.2025
При разработке программного обеспечения на языке Java программисты часто сталкиваются с необходимостью эффективного управления наборами данных. Массивы и ArrayList являются двумя фундаментальными. . .
Как сгенерировать случайные целые числа (int) в указанном диапазоне в Java
bytestream 25.01.2025
В программировании генерация случайных чисел является важнейшим инструментом для решения множества практических задач. От создания игровых механик до реализации алгоритмов машинного обучения, от. . .
Как сделать, чтобы grep выводил строки до и после найденной
hw_wired 25.01.2025
Утилита grep стала незаменимым инструментом для поиска и фильтрации информации в Unix-подобных операционных системах. Эта командная утилита позволяет осуществлять поиск строк, соответствующих. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru