Один настраиваемый запрос MySQL или несколько запросов Hibernate, что более эффективно?

Мне нужно получить все столбцы из 5 таблиц. Набор результатов может возвращать до 1000 строк.

Что лучше: написать один пользовательский запрос в MySQL для получения всех данных или использовать 5 запросов Hibernate для получения данных?

Условия - В таблице 1 индекс представляет собой комбинацию первичного ключа и другого столбца, по которому разбита база данных. В остальных таблицах первичный ключ таблицы 1 является внешним ключом и имеет тот же столбец в остальных таблицах для разделения таблицы.

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

Эмпирическое правило: чем меньше обращений к базе данных, тем лучше - «1» является оптимальным.

Strawberry 04.12.2018 07:51
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
Освоение архитектуры микросервисов с Laravel: Лучшие практики, преимущества и советы для разработчиков
В последние годы архитектура микросервисов приобрела популярность как способ построения масштабируемых и гибких приложений. Laravel , популярный PHP...
Как построить CRUD-приложение в Laravel
Как построить CRUD-приложение в Laravel
Laravel - это популярный PHP-фреймворк, который позволяет быстро и легко создавать веб-приложения. Одной из наиболее распространенных задач в...
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
Освоение PHP и управление базами данных: Создание собственной СУБД - часть II
В предыдущем посте мы создали функциональность вставки и чтения для нашей динамической СУБД. В этом посте мы собираемся реализовать функции обновления...
Документирование API с помощью Swagger на Springboot
Документирование API с помощью Swagger на Springboot
В предыдущей статье мы уже узнали, как создать Rest API с помощью Springboot и MySql .
Роли и разрешения пользователей без пакета Laravel 9
Роли и разрешения пользователей без пакета Laravel 9
Этот пост изначально был опубликован на techsolutionstuff.com .
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
Как установить LAMP Stack - Security 5/5 на виртуальную машину Azure Linux VM
В предыдущей статье мы завершили установку базы данных, для тех, кто не знает.
0
1
61
1

Ответы 1

Я всегда буду избегать HQL, если запрос будет сложным.

Ценность Hibernate или другого ORM - производительность и удобство. Им никогда не перехитрить хорошего разработчика.

Все, что сгенерировано Hibernate, по-прежнему является SQL-запросом. Они НИКОГДА не могут быть эффективнее хорошо написанных SQL-запросов.

Другие вопросы по теме