繁体   English   中英

错误:运算符不存在:时间戳不带时区 >= 布尔值 提示:没有运算符匹配给定的名称和参数类型

[英]ERROR: operator does not exist: timestamp without time zone >= boolean Hint: No operator matches the given name and argument type(s)

我正在尝试使用 JPA 执行命名查询。 查询必须根据查询条件搜索和提取记录。 标准是查询应该在特定给定时间(提供从和到日期之间的记录)和应用程序名称之间提取记录。

在 Postgresql 中执行时,查询工作正常。 但是,通过 JPA 它在执行查询时出错

Here is my Query in PostgreSQL :
SELECT  auditLog.busn_sys_id            
        , sourceSystem.busn_sys_full_nm     
        , auditLog.purge_ts                 
        , auditLog.rec_purge_cnt            

FROM    rec_ret.rec_rtn_purge_adt                   auditLog
LEFT    JOIN    gbl_dm.gbl_busn_sys_dm              sourceSystem            on (auditLog.busn_sys_id = sourceSystem.busn_sys_id)

    WHERE   (auditLog.purge_ts BETWEEN '2019-08-19' AND '2019-08-25')
      and  sourceSystem.busn_sys_full_nm like 'PROFILE' 

    order by auditLog.busn_sys_id ;

这是我获取结果列表的 JPA 实现

try{

            Query query = entityManager.createNativeQuery("SELECT auditLog.busn_sys_id, sourceSystem.busn_sys_full_nm, auditLog.purge_ts, auditLog.rec_purge_cnt " +
                    "FROM rec_ret.rec_rtn_purge_adt auditLog " +
                    "LEFT JOIN gbl_dm.gbl_busn_sys_dm sourceSystem on (auditLog.busn_sys_id = sourceSystem.busn_sys_id) " +
                    "WHERE (auditLog.purge_ts BETWEEN auditLog.purge_ts = :requestedFrom AND auditLog.purge_ts = :requestedTo) " +
                    //"WHERE (auditLog.purge_ts BETWEEN requestedFrom = (?) AND requestedTo = (?)) " +
                    "and  sourceSystem.busn_sys_full_nm = :sourceSystem " +
                    "order by auditLog.busn_sys_id ");

            query.setParameter("requestedFrom",auditLogCriteria.getFromDate());
            query.setParameter("requestedTo",auditLogCriteria.getToDate());
            query.setParameter("sourceSystem",auditLogCriteria.getSourceSystem());;

            query.executeUpdate();
            return query.getResultList();


        }catch (Exception e){
            logger.error("Fetching of logs failed with message : " + e.getMessage());
            throw e;
        }

这是我对实体/模型类代码的实现

@NotNull (message = "Name of the Source System should be entered")
    private String sourceSystem;

    @NotNull (message = "Specify FromDate to filter records")
    @JsonFormat(shape = JsonFormat.Shape.STRING, pattern="yyyy-MM-dd HH:mm:ss[.SSS]")
    @Convert(converter = LocalDateTimeConverter.class)
    private LocalDateTime fromDate;

    @NotNull (message = "Specify ToDate to filter records")
    @JsonFormat(shape = JsonFormat.Shape.STRING, pattern="yyyy-MM-dd HH:mm:ss[.SSS]")
    @Convert(converter = LocalDateTimeConverter.class)
    private LocalDateTime toDate;
\\ Getters and Setters

这是错误:

Hibernate: SELECT auditLog.busn_sys_id, sourceSystem.busn_sys_full_nm, auditLog.purge_ts, auditLog.rec_purge_cnt FROM rec_ret.rec_rtn_purge_adt auditLog LEFT JOIN gbl_dm.gbl_busn_sys_dm sourceSystem on (auditLog.busn_sys_id = sourceSystem.busn_sys_id) WHERE (auditLog.purge_ts BETWEEN auditLog.purge_ts = ? AND auditLog.purge_ts = ?) and  sourceSystem.busn_sys_full_nm = ? order by auditLog.busn_sys_id 

[ERROR] 2019-08-29 10:02:00.558 [http-nio-8080-exec-2] SqlExceptionHelper - ERROR: operator does not exist: timestamp without time zone >= boolean
  Hint: No operator matches the given name and argument type(s). You might need to add explicit type casts.
  Position: 267
javax.persistence.PersistenceException: org.hibernate.exception.SQLGrammarException: could not execute statement
    at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:154)
    at org.hibernate.internal.ExceptionConverterImpl.convert(ExceptionConverterImpl.java:181)
    at org.hibernate.query.internal.AbstractProducedQuery.executeUpdate(AbstractProducedQuery.java:1593)

因此,结果应该是所有与条件匹配的记录都必须作为对 JSON 请求的响应返回

您的 JPA 查询的这一部分看起来有误:

BETWEEN auditLog.purge_ts = :requestedFrom AND auditLog.purge_ts = :requestedTo

我觉得应该是:

BETWEEN :requestedFrom AND :requestedTo

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM