Пользовательский запрос JPA с предложением IN, допускающим значение NULLJAVA

Программисты JAVA общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 Пользовательский запрос JPA с предложением IN, допускающим значение NULL

Сообщение Anonymous »

Я пытаюсь написать собственный запрос в своем приложении SpringBoot с использованием JPA. У меня есть предложение IN со списком значений (список также может быть нулевым). Я написал такой запрос:

Код: Выделить всё

@Query( "SELECT new com.mypackage.model.CustomOutput( AVG(t.time) ) " +
"FROM MyTable t WHERE " +
"t.time IS NOT NULL AND t.updatedTime > :after AND t.updatedTime < :before " +
"AND " +
"( (:filterA) IS NULL OR t.columnA IN (:filterA) ) AND " +
"( (:filterB) IS NULL OR t.columnB IN (:filterB) ) AND " +
"( (:filterC) IS NULL OR t.columnC IN (:filterC) ) AND " +
"( (:filterD) IS NULL OR t.columnD IN (:filterD) )"
)
CustomOutput findCustomOutput(
@Param("filterA") List filterA,
@Param("filterC") List filterC,
@Param("filterB") List filterB,
@Param("filterD") List filterD,
@Param("after") Date after,
@Param("before") Date before
);
Все фильтры — A,B,C,D могут быть списком значений или нулевыми значениями. Запрос работает нормально, если любой из фильтров имеет значение
  • null
  • одиночное значение.
Запрос завершается неудачно, если есть более одного значения
(Например: фильтры — A,B,C имеют значение NULL, D — список из двух значений). Исключением является
:

Код: Выделить всё

2024-06-28 12:32:32,543 [collectorsCluster_Worker-1] WARN  o.h.e.jdbc.spi.SqlExceptionHelper - SQL Error: 920, SQLState: 42000
2024-06-28 12:32:32,544 [collectorsCluster_Worker-1] ERROR o.h.e.jdbc.spi.SqlExceptionHelper - ORA-00920: invalid relational operator

2024-06-28 12:32:32,559 [collectorsCluster_Worker-1] ERROR c.c.d.job.servicenow.ServiceNowJob - Unexpected error occurred -
org.springframework.dao.InvalidDataAccessResourceUsageException: could not extract ResultSet; SQL [n/a]; nested exception is org.hibernate.exception.SQLGrammarException: could not extract ResultSet
at org.springframework.orm.jpa.vendor.HibernateJpaDialect.convertHibernateAccessException(HibernateJpaDialect.java:259)
at org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateExceptionIfPossible(HibernateJpaDialect.java:233)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.translateExceptionIfPossible(AbstractEntityManagerFactoryBean.java:551)
at org.springframework.dao.support.ChainedPersistenceExceptionTranslator.translateExceptionIfPossible(ChainedPersistenceExceptionTranslator.java:61)
at org.springframework.dao.support.DataAccessUtils.translateIfNecessary(DataAccessUtils.java:242)
at org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:152)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.data.jpa.repository.support.CrudMethodMetadataPostProcessor$CrudMethodMetadataPopulatingMethodInterceptor.invoke(CrudMethodMetadataPostProcessor.java:145)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:97)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:215)
at com.sun.proxy.$Proxy231.findCustomOutput(Unknown Source)
База данных — Oracle. Может ли кто-нибудь указать на проблему в синтаксисе?

Подробнее здесь: https://stackoverflow.com/questions/786 ... -in-clause
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «JAVA»