播放框架 - 使用带有Option [LocalDate] \ Option [LocalDateTime]的anorm

时间:2015-11-16 08:10:38

标签: scala datetime playframework-2.0 anorm

我正在尝试在postgres中定义一个可以为空的日期字段,同时使用anorm作为数据库的连接。

我正在尝试更新条目:

def update(id: Long, startTime: Option[LocalDate]){
   SQL("""UPDATE my_table
        |SET start_date = {start_date}
        |WHERE id = {id}
      """.stripMargin)
      .on(
        'id ->id,
        'start_date -> startDate,
      ).executeUpdate()
 }

但是我得到了一个编译错误,看起来anorm无法处理Option [DateTime],虽然当我配置一个解析器时它起作用了我:

val parser: RowParser[Info] = {
  get[Long]("id") ~
  get[Option[DateTime]]("start_date") map {
  case id ~ startTime => Info(id, startDate)
}

}

我在这里缺少什么? 谢谢!

2 个答案:

答案 0 :(得分:0)

我添加了自己的隐含定义:

implicit def rowToLocalDate: Column[LocalDate] = Column.nonNull {(value, meta) =>
   val MetaDataItem(qualified, nullable, clazz) = meta
   value match {
      case ts: java.sql.Timestamp => Right(new LocalDate(ts.getTime))
      case d: java.sql.Date => Right(new LocalDate(d.getTime))
      case str: java.lang.String => Right(fmt.parseLocalDate(str))
      case _ => Left(TypeDoesNotMatch("Cannot convert " + value + ":" + value.asInstanceOf[AnyRef].getClass) )
}

}

implicit val localDateToStatement = new ToStatement[LocalDate] {
    def set(s: java.sql.PreparedStatement, index: Int, aValue: LocalDate): Unit = {
       s.setTimestamp(index, new java.sql.Timestamp(aValue.toDateTimeAtStartOfDay().getMillis()))
}

}

和相关的ParameterMetaData

implicit object LocalDateClassMetaData extends  ParameterMetaData[LocalDate] {
   val sqlType = ParameterMetaData.DateParameterMetaData.sqlType
   val jdbcType = ParameterMetaData.DateParameterMetaData.jdbcType
}

这就是诀窍

答案 1 :(得分:0)

相关问题,Anorm compare/search by java.time LocalDateTime它对我有用的只是更新到新版本(尚未发布一个)