JPA / Hibernate запрос с именем класса? - PullRequest
6 голосов
/ 23 февраля 2010

В этом примере com.test.Cat расширяет com.test.Animal, и в CAT таблице com.test.Cat нет поля DB, явно определяющего его тип (это был не я).

Когда я запрашиваю своих животных из БД, я получаю коллекцию животных.

Можно отсортировать их по имени класса:

order by r.class

но есть ли способ использовать имя класса в качестве критерия? Например, я хотел бы, чтобы все животные ожидали собак. Но не повезло - даже это не работает:

where r.class = ?      (String "ccc.test.Cat")

как я получаю исключение:

Caused by: java.lang.ClassCastException: java.lang.String cannot be cast to java.lang.Integer
    at org.hibernate.type.IntegerType.set(IntegerType.java:64)
    at org.hibernate.type.NullableType.nullSafeSet(NullableType.java:154)
    at org.hibernate.type.NullableType.nullSafeSet(NullableType.java:136)
    at org.hibernate.param.PositionalParameterSpecification.bind(PositionalParameterSpecification.java:62)
    at org.hibernate.loader.hql.QueryLoader.bindParameterValues(QueryLoader.java:514)
    at org.hibernate.loader.Loader.prepareQueryStatement(Loader.java:1589)
    at org.hibernate.loader.Loader.doQuery(Loader.java:696)
    at org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:259)
    at org.hibernate.loader.Loader.doList(Loader.java:2228)
    at org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2125)
    at org.hibernate.loader.Loader.list(Loader.java:2120)
    at org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:401)
    at org.hibernate.hql.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:361)
    at org.hibernate.engine.query.HQLQueryPlan.performList(HQLQueryPlan.java:196)
    at org.hibernate.impl.SessionImpl.list(SessionImpl.java:1148)
    at org.hibernate.impl.QueryImpl.list(QueryImpl.java:102)
    at org.hibernate.ejb.QueryImpl.getResultList(QueryImpl.java:67)

1 Ответ

6 голосов
/ 23 февраля 2010

Согласно главе 14.9 документации, вы не должны использовать двойные кавычки:

Доступ к классу специальных свойств значение дискриминатора экземпляра в случае полиморфного упорство. Имя класса Java встроен в пункт, где будет переводится в значение дискриминатора.

from Cat cat where cat.class = DomesticCat
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...