Напечатанные вопросы для небытия заканчиваются с JPQL

TypedQuery query = entityManager.createQuery(
  "select new com.loki2302.JPQLTest$UserNameAndPostCount" + 
  "(u.userName, count(p.id)) " +
  "from User u " + 
  "left join u.posts p group by u.userName", UserNameAndPostCount.class);

List resultList = query.getResultList();

Есть ли любой "официальный" способ сделать то же самое без жесткого кодирования com.loki2302. JPQLTest$UserNameAndPostCount в тексте запроса JPQL?

1

2 ответы

Вопрос как

entityManager.createQuery("SELECT u.userName, count(p.id) FROM User u LEFT JOIN u.posts p GROUP BY u.userName", UserNameAndPostCount.class);

вероятно, работал бы над некоторыми внедрениями JPA, конечно DataNucleus JPA цели сделать такие вещи. В конце концов, последний аргумент - класс результата, таким образом, его в основном высказывание создает меня объекты того типа с этими областями результата как аргументы (или используйте сеттеров с именами, согласовывающимися с теми двумя областями результата), и можно легко достаточно поместить "КАК {псевдоним}" в избранном пункте, чтобы заставить области результата соответствовать именам свойства компонента в классе результата.

1
добавлено

избегать этого трудного кодирования вас может использовать createNamedQuery (Последовательность) интерфейса entityManager. чтобы использовать этот метод, необходимо создать NamedQueries в модели (класс предприятия) и объект Вопроса использования вместо этого TypedQuery.

0
добавлено
как это собирается избежать "нового com.loki2302. JPQLTest$UserNameAndPostCount" часть вопроса? Это isn' t
добавлено автор Neil Stockton, источник
pro.jvm
pro.jvm
3 503 участник(ов)

Сообщество разработчиков Java Scala Kotlin Groovy Clojure Чат для нач-их: @javastart Наш сайт: projvm.com projvm.ru Наш канал: @proJVM Вакансии: @jvmjobs Конфы: @jvmconf

Java & Co
Java & Co
2 370 участник(ов)

Можно обсуждать с матом и без всё, что касается жабы, вплоть до холиваров. НЕ ИМЕЕТ ОТНОШЕНИЯ К САЙТУ JAVARUSH.RU ПРАВИЛА - https://t.me/javarush/75723 Вакансии сюда - https://telegram.me/joinchat/B7IzvUCnfo6d8t3yIxKguQ По вопросам - @thedude

learn.java
learn.java
1 888 участник(ов)

Чат для начинающих и не только Статистика: https://combot.org/chat/-1001083535868 Основной чат - @jvmchat

Java Underground
Java Underground
169 участник(ов)

https://vk.com/javatutorial

Javanese Questions
Javanese Questions
109 участник(ов)

Чат предназначен для обмена знаниями строго в формате в вопрос-ответ. Тема — Java, Kotlin и Android. Вопрос должен быть предварительно прогуглен, понятно и грамотно сформулирован, помечен хэштегами. Ответ — тем более. Куски кода размером в несколько строк можно писать прямо здесь, для больших кусков кода стоит использовать http://gist.github.com/, http://pastebin.com/, https://codeshare.io/ или любой аналогичный сервис. В некоторых случаях можно прикреплять скриншоты. Стикеры и гифки запрещены. Дополнять и уточнять вопросы и ответы — редактированием исходного сообщения. Обсуждения должны приводить к редактированию вопроса/ответа и удаляться. По хештегам можно искать существующие вопросы и овтеты: #вопрос #ответ #git #generics #java #server #awt #javafx #swing #kotlin #anko #tornadofx #ktor #android #recyclerView #performance #arch #network #permissions #storage #async