【问题标题】:Hibernate and SQL Server : Timestamp format must be yyyy-mm-dd hh:mm:ssHibernate 和 SQL Server:时间戳格式必须为 yyyy-mm-dd hh:mm:ss
【发布时间】:2015-12-04 12:44:30
【问题描述】:

我在我的应用程序中使用休眠来查询 MySQL 数据库的数据。现在我正在尝试查询 SQL Server,但我发现了有关日期类型的这个问题。

SQL 服务器中的表Foo 有一个created_at 类型为datetime 的列

相关的 pojo foo 有一个 createdAt 类型为 java.util.Date 的字段

@Entity
@Table(name="foo")
public class Foo {

....
    @Column(name="created_at")
    private Date createdAt;

.....
}

但是,如果我执行类似的 hql:

Query query = entityManager.createQuery("select f from Foo f");
    query.getResultList();

我得到以下异常:

Caused by: com.microsoft.sqlserver.jdbc.SQLServerException: Error al convertir el valor nvarchar al tipo de datos JDBC TIMESTAMP.
    at com.microsoft.sqlserver.jdbc.DDC.convertStreamToObject(DDC.java:456)
    at com.microsoft.sqlserver.jdbc.ServerDTVImpl.getValue(dtv.java:2007)
    at com.microsoft.sqlserver.jdbc.DTV.getValue(dtv.java:175)
    at com.microsoft.sqlserver.jdbc.Column.getValue(Column.java:113)
    at com.microsoft.sqlserver.jdbc.SQLServerResultSet.getValue(SQLServerResultSet.java:1982)
    at com.microsoft.sqlserver.jdbc.SQLServerResultSet.getValue(SQLServerResultSet.java:1967)
    at com.microsoft.sqlserver.jdbc.SQLServerResultSet.getTimestamp(SQLServerResultSet.java:2377)
    at org.hibernate.type.descriptor.sql.TimestampTypeDescriptor$2.doExtract(TimestampTypeDescriptor.java:75)
    at org.hibernate.type.descriptor.sql.BasicExtractor.extract(BasicExtractor.java:64)
    at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:267)
    at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:263)
    at org.hibernate.type.AbstractStandardBasicType.nullSafeGet(AbstractStandardBasicType.java:253)
    at org.hibernate.type.AbstractStandardBasicType.hydrate(AbstractStandardBasicType.java:338)
    at org.hibernate.persister.entity.AbstractEntityPersister.hydrate(AbstractEntityPersister.java:2969)
    at org.hibernate.loader.plan.exec.process.internal.EntityReferenceInitializerImpl.loadFromResultSet(EntityReferenceInitializerImpl.java:324)
    ... 78 more
Caused by: java.lang.IllegalArgumentException: Timestamp format must be yyyy-mm-dd hh:mm:ss[.fffffffff]
    at java.sql.Timestamp.valueOf(Timestamp.java:202)
    at com.microsoft.sqlserver.jdbc.DDC.convertStringToObject(DDC.java:306)
    at com.microsoft.sqlserver.jdbc.DDC.convertStreamToObject(DDC.java:419)
    ... 92 more

我怎样才能解决这个问题,让我的后端代码可以同时与 MySQL 和 MS SQL Server 一起使用?

【问题讨论】:

标签: java sql-server hibernate jpa


【解决方案1】:

尝试使用这个...

@Column(name="created_at")
@Temporal(TemporalType.TIMESTAMP)
private Date createdAt;

同时显示它在 DB 中的存储格式。

【讨论】:

    【解决方案2】:

    我使用 java.sql.Date 或 java.sql.Timestamp 并为我工作,没有 @Temporal 的注释。

    顺便说一句,当您设置新值时,您需要将它们转换为 java.sql.Date 或类似的。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-06-16
      • 2017-07-09
      • 2021-05-04
      • 2014-12-26
      • 2023-03-04
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多