Java Hibernate和SQL Server:时间戳格式必须为yyyy-mm-dd hh:mm:ss

Java Hibernate和SQL Server:时间戳格式必须为yyyy-mm-dd hh:mm:ss,java,sql-server,hibernate,jpa,Java,Sql Server,Hibernate,Jpa,我在应用程序中使用hibernate查询MySQL数据库的数据。现在我尝试查询一个SQL Server,我发现了这个关于日期类型的问题 SQL server中的表Foo在处创建了一列datetime 相关的pojo foo有一个类型为java.util.Date @Entity @Table(name="foo") public class Foo { .... @Column(name="created_at") private Date createdAt; .....

我在应用程序中使用hibernate查询MySQL数据库的数据。现在我尝试查询一个SQL Server,我发现了这个关于日期类型的问题

SQL server中的表
Foo
处创建了一列
datetime

相关的pojo foo有一个类型为
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?

尝试使用这个

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

还显示了它在DB中存储的格式。

我使用java.sql.Date或java.sql.Timestamp,并且在不使用@Temporal的情况下为我工作


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

尝试将此注释添加到您的字段:@Temporal(TemporalType.TIMESTAMP),这可能会有所帮助