Реализуют ли ORM-фреймворки, такие как hibernate, какие-либо средства отображения строк при итерации по набору результатов? Если не реализуется преобразователь строк, они, по крайней мере, выполняют итерацию набора результатов при создании списка сущностей или они напрямую получают список сущностей в качестве набора результатов? т.е. внутренняя работа createQuery("from Employee").getResultlist();
И если мы используем собственный запрос, возвращает ли он набор результатов напрямую или выполняет итерацию по набору результатов и возвращает список массивов объектов, то есть List<Object[]>?




Если вы спрашиваете, использует ли Hibernate какое-то объектно-ориентированное расширение при запросе: Hibernate работает с большим количеством баз данных, он не может использовать расширения поставщиков OO, потому что они не будут стандартизированы.
Если вы посмотрите на аннотации или сопоставления для сущности, они сообщают, в какой столбец сопоставлено каждое свойство. Итак, да, у него есть функция сопоставления строк, где он генерирует запрос, сопоставляет столбцы со свойствами и заполняет объекты из него.
Вы можете увидеть, как SQL Hibernate генерирует, установив уровень журнала для logger org.hibernate.sql на DEBUG.