Мне нужно получить все столбцы из 5 таблиц. Набор результатов может возвращать до 1000 строк.
Что лучше: написать один пользовательский запрос в MySQL для получения всех данных или использовать 5 запросов Hibernate для получения данных?
Условия - В таблице 1 индекс представляет собой комбинацию первичного ключа и другого столбца, по которому разбита база данных. В остальных таблицах первичный ключ таблицы 1 является внешним ключом и имеет тот же столбец в остальных таблицах для разделения таблицы.
(Из-за некоторых ограничений - 1. эти данные нельзя кэшировать. 2. Вызовы с разбивкой на страницы невозможны. 3. Активную или ленивую загрузку, поддерживаемую Hibernate, использовать нельзя)






Я всегда буду избегать HQL, если запрос будет сложным.
Ценность Hibernate или другого ORM - производительность и удобство. Им никогда не перехитрить хорошего разработчика.
Все, что сгенерировано Hibernate, по-прежнему является SQL-запросом. Они НИКОГДА не могут быть эффективнее хорошо написанных SQL-запросов.
Эмпирическое правило: чем меньше обращений к базе данных, тем лучше - «1» является оптимальным.