无法将 1985-04-12T23:20 转换为 java.util.Date
Failed to convert 1985-04-12T23:20 into java.util.Date
[Spring + Kotlin]
这些是依赖项:
implementation("org.springframework.boot:spring-boot-starter-data-jpa")
implementation("org.springframework.boot:spring-boot-starter-data-rest")
implementation("org.springframework.boot:spring-boot-starter-web")
implementation("org.springframework.boot:spring-boot-starter-web-services")
implementation("com.fasterxml.jackson.module:jackson-module-kotlin")
implementation("com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.4.0")
implementation("org.jetbrains.kotlin:kotlin-reflect")
implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
这是实体:
@Entity
class MatchEntity(
@Id @GeneratedValue val id: Long,
@NotBlank val matchDateTime: Date,
@NotBlank @ManyToOne @JoinColumn val tournamentInvolved: TournamentEntity
)
每当我尝试 运行 以下查询时:
interface MatchRepository : JpaRepository<MatchEntity, Long> {
fun findMatchesByMatchDateTimeIsAfter(matchDateTime: Date)
}
使用像这样的测试字符串 1985-04-12T23:20
,我得到错误:
QueryMethodParameterConversionException: Failed to convert 1985-04-12T23:20 into java.util.Date!
我按照建议 here 尝试在查询方法的签名中使用 @DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME)
和 @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm")
等模式,但没有解决。
此外,按照建议 ,我尝试添加
compile("com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.4.0")
到依赖项
spring.jackson.serialization.write_dates_as_timestamps=false
到application.properties。
没有成功。
更新:
我还尝试使用 LocalDateTime 和 Instant 类。仍然得到相同的异常:
QueryMethodParameterConversionException: Failed to convert 1985-04-12T23:20 into java.time.LocalDateTime!
QueryMethodParameterConversionException: Failed to convert 1985-04-12T23:20 into java.time.Instant!
已解决
使用 @DateTimeFormat(pattern = "yyyy-MM-dd'T'HH:mm")
有效。
[Spring + Kotlin]
这些是依赖项:
implementation("org.springframework.boot:spring-boot-starter-data-jpa")
implementation("org.springframework.boot:spring-boot-starter-data-rest")
implementation("org.springframework.boot:spring-boot-starter-web")
implementation("org.springframework.boot:spring-boot-starter-web-services")
implementation("com.fasterxml.jackson.module:jackson-module-kotlin")
implementation("com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.4.0")
implementation("org.jetbrains.kotlin:kotlin-reflect")
implementation("org.jetbrains.kotlin:kotlin-stdlib-jdk8")
这是实体:
@Entity
class MatchEntity(
@Id @GeneratedValue val id: Long,
@NotBlank val matchDateTime: Date,
@NotBlank @ManyToOne @JoinColumn val tournamentInvolved: TournamentEntity
)
每当我尝试 运行 以下查询时:
interface MatchRepository : JpaRepository<MatchEntity, Long> {
fun findMatchesByMatchDateTimeIsAfter(matchDateTime: Date)
}
使用像这样的测试字符串 1985-04-12T23:20
,我得到错误:
QueryMethodParameterConversionException: Failed to convert 1985-04-12T23:20 into java.util.Date!
我按照建议 here 尝试在查询方法的签名中使用 @DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME)
和 @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm")
等模式,但没有解决。
此外,按照建议
compile("com.fasterxml.jackson.datatype:jackson-datatype-jsr310:2.4.0")
到依赖项spring.jackson.serialization.write_dates_as_timestamps=false
到application.properties。
没有成功。
更新: 我还尝试使用 LocalDateTime 和 Instant 类。仍然得到相同的异常:
QueryMethodParameterConversionException: Failed to convert 1985-04-12T23:20 into java.time.LocalDateTime!
QueryMethodParameterConversionException: Failed to convert 1985-04-12T23:20 into java.time.Instant!
已解决
使用 @DateTimeFormat(pattern = "yyyy-MM-dd'T'HH:mm")
有效。