java - JPA 中的日期时间表达式作为参数传递

标签 java spring hibernate datetime

我想比较 JPA 中的日期时间函数。只是想知道如何通过。顺便说一句,我对 JPA 很陌生。我的输入日期将如下所示 28/12/2014 16:20 我将其解析为日期

我必须将其作为参数传递,但数据库表(MS SQL)由日期时间格式组成,如2014-12-28 16:20:38.107

这是我的代码。

@Entity下(我无法编辑此代码,因为我没有权限这样做。无论如何其他方法正在访问此实体,我只是重用它)

    @Column(name = "PublishDate", nullable = false)
    private Date publishDate;

我的实际代码

    Date date = simpleDateFormat.parse(s);
    Message.findByPublishDate(date);

使用 Debug=true 运行上述代码后,我在 sql 查询中看到传递的参数为: messages0_.PublishDate=? 这意味着它甚至没有获取日期,我收到以下异常

select operations0_.OperationsMessageID as Operatio1_10_, operations0_.Content as Content2_10_, 
operations0_.CreatedDate as CreatedD3_10_, operations0_.ExpiryDate as ExpiryDa4_10_, 
operations0_.PublishDate as PublishD5_10_, operations0_.Status as Status6_10_, operations0_.Title 
as Title7_10_, operations0_.OperationsMessageTypeID as Operatio8_10_ from OperationsMessage 
operations0_ where operations0_.PublishDate=?

异常详细信息:

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:172)
at org.springframework.orm.jpa.vendor.HibernateJpaDialect.translateExceptionIfPossible(HibernateJpaDialect.java:155)
at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.translateExceptionIfPossible(AbstractEntityManagerFactoryBean.java:417)
at org.springframework.dao.support.ChainedPersistenceExceptionTranslator.translateExceptionIfPossible(ChainedPersistenceExceptionTranslator.java:59)
at org.springframework.dao.support.DataAccessUtils.translateIfNecessary(DataAccessUtils.java:213)
at org.springframework.dao.support.PersistenceExceptionTranslationInterceptor.invoke(PersistenceExceptionTranslationInterceptor.java:147)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.data.jpa.repository.support.LockModeRepositoryPostProcessor$LockModePopulatingMethodIntercceptor.invoke(LockModeRepositoryPostProcessor.java:105)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:207)
at com.sun.proxy.$Proxy44.findByPublishDate(Unknown Source)

最佳答案

您的 Spring Data 生成的 JPQL 查询很可能无法正常工作,因为您的列定义缺少 @Temporal注解。规范规定此注释必须指定给任何 java.util.Datejava.util.Calendar 类型的列。

我知道您说过无法更改它,但我认为没有其他选择:

    @Temporal(TemporalType.DATE)
    @Column(name = "PublishDate", nullable = false)
    private Date publishDate;

如果物理数据库列是时间戳 SQL 类型,您可能需要 TemporalType.TIMESTAMP。

或者,该列已指定为 java.sql.Date 。如果是这种情况,那么您可能需要使用该日期类型作为 findByPublishDate 的参数,从 java.util.Date 进行转换:

    Message.findByPublishDate(new java.sql.Date(date.getTime()));

关于java - JPA 中的日期时间表达式作为参数传递,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27261812/

相关文章:

java - 安卓 Java : changing image in listview depending on content

java - 使用 getCurrentSession() 时出现 "No Session found for current thread"异常

java - Hibernate 条件查询。创建子标准后,我可以返回原始标准吗?

java - 使用 Spring、Hibernate 和 Spring Transaction Support 为单元测试设置数据库

java - p :dataList cannot iterate java. util.Set

java - 删除 TreeSet 的匹配元素

java - 如何使用不同类的 JButton 打开新的 JFrame

java - 如何通过 Maven 将 Google 的 OAuth 客户端导入 IntelliJ?

java - Spring 3 - InternalResourceViewResolver 不显示我的 jsp 页面

java - 在 Spring 中 Autowiring 共享队列的正确方法