Как отобразить результат запроса в настраиваемый объект, который не является сущностью?

Этот запрос здесь в основном работает так, как задумано:

@Query("SELECT " +
       "   votedItem.groupVoting.id AS votingId, " +
       "   COUNT(votedItem) AS nbVotes " +
       "FROM VotingVotedItemEntity votedItem " +
       "WHERE votedItem.id IN :votingIds " +
       "GROUP BY votedItem.id, votedItem.item.id")
List<Object> findItemVoteCountsByVotingIds(@Param("votingIds") List<Long> votingIds);

Моя проблема в том, что я не могу передать результат в объект. Запрос не окончательный, но, в конце концов, он должен быть отображен в класс:

public class ItemVotes 
{
    private String name;
    private Integer voteCount;
    /*  Getter & setter */
}

Я не знаю, куда идти. На этом этапе я думаю, что мне придется создать собственный JpaRepository:

public interface VoteCountsRepository extends JpaRepository<ItemVotes, Long> {
}

но это не работает, поскольку сервер умирает при запуске в

IllegalArgumentException: Not a managed type

Может ли кто-нибудь объяснить мне, как здесь отображать пользовательские типы в объекты?

Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
0
36
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы должны уметь что-то делать нравится:

@Query("SELECT " +
       "   new package.of.class.ItemVotes(votedItem.groupVoting.id AS votingId, " +
       "   COUNT(votedItem) AS nbVotes) " +
       "FROM VotingVotedItemEntity votedItem " +
       "WHERE votedItem.id IN :votingIds " +
       "GROUP BY votedItem.id, votedItem.item.id")
List<ItemVotes> findItemVoteCountsByVotingIds(@Param("votingIds") List<Long> votingIds);

Вызывается Выражение конструктора JPQL.

Но нужен ли для этого собственный JpaRepository<ItemVotes, Long> или он должен работать где угодно?

Stefan Falk 14.09.2018 17:47

Он будет работать где угодно. Я думаю, вы, вероятно, захотите поместить его в свой VotedItemRepository, поскольку эти данные указывают на количество проголосованных пунктов ...

Dovmo 14.09.2018 17:56

Хм. Ладно, похоже, это работает, и нет более лучшего способа, чем этот? Это действительно заставляет меня задуматься, почему я использую ORM, если мне нужно писать запросы, которые выглядят так: D

Stefan Falk 14.09.2018 18:12

Вы можете написать свой собственный Запрос гибернации. Но для того, что вы делаете, это определенно самый чистый способ сделать это. IMHO вам не нужно было резко менять запрос, и он все еще намного чище, чем написание собственного запроса, выполнение соединений и создание некоторого отображения гибернации или тому подобное.

Dovmo 14.09.2018 18:19

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