2016-06-01 58 views
1

我使用Hibernate并希望仅在数据库中保存时间,因此我将字段声明为Date并使用时间类型时间对其进行注释,但它引发了有关格式的错误。在数据库中仅使用休眠节省时间

模式

@Entity 
@Table(name = "working_policy") 
public class OrganizationWorkingPolicy { 

    @Id 
    @GeneratedValue(strategy = GenerationType.AUTO) 
    @Column(name= "policy_id") 
    private long policyId; 

    @NotEmpty 
    @NotNull 
    @Column(name= "day") 
    private String day; 

    @DateTimeFormat(pattern="hh:mm:ss") 
    @Temporal(TemporalType.TIME) 
    @Column(name = "start_time") 
    private Date startTime; 

    @DateTimeFormat(pattern="HH:mm:ss") 
    @Temporal(TemporalType.TIME) 
    @Column(name = "end_time") 
    private Date endTime; 

    // getter and setters 
} 

错误

Servlet.service() for servlet [dispatcher] in context with path [/AppointmentSchedular] threw exception [Request processing failed; nested exception is java.lang.IllegalArgumentException: Can not construct instance of java.util.Date from String value '12:20:00': not a valid representation (error: Failed to parse Date value '12:20:00': Can not parse date "12:20:00": not compatible with any of standard forms ("yyyy-MM-dd'T'HH:mm:ss.SSSZ", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", "EEE, dd MMM yyyy HH:mm:ss zzz", "yyyy-MM-dd")) 
at [Source: N/A; line: -1, column: -1] (through reference chain: com.appoitment.schedular.model.OrganizationWorkingPolicy["startTime"])] with root cause 
com.fasterxml.jackson.databind.exc.InvalidFormatException: Can not construct instance of java.util.Date from String value '12:20:00': not a valid representation (error: Failed to parse Date value '12:20:00': Can not parse date "12:20:00": not compatible with any of standard forms ("yyyy-MM-dd'T'HH:mm:ss.SSSZ", "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", "EEE, dd MMM yyyy HH:mm:ss zzz", "yyyy-MM-dd")) 
at [Source: N/A; line: -1, column: -1] (through reference chain: com.appoitment.schedular.model.OrganizationWorkingPolicy["startTime"]) 
+0

请参阅http://www.developerscrappad.com/228/java/java-ee/ejb3-jpa-dealing-with-date-time-and-timestamp/ –

回答

2

尝试在Hibernate实体类使用java.sql.Time;代替import java.util.Date;,它应该工作。