scala - 如何在 slick 3.0 的过滤器上比较 column[option[DateTime] 与 DateTime.now

标签 scala datetime slick-3.0

我有下一个问题..

我正在使用 spray.http.DateTime,我的映射器是:

  implicit val JavaUtilDateTimeMapper =
    MappedColumnType.base[DateTime, Timestamp] (
      d => new Timestamp(d.clicks),
      d => spray.http.DateTime(d.getTime))


 case class EventosModelTable(
  id: Option[Long],
  idCliente: Option[Long],
  idPlan: Option[Long] = None,
  idServicio: Option[Long] = None,
  tipo: TipoEventos.Value,
  fechaInicio: DateTime,
  fechaFin: Option[DateTime]
) extends BaseModel

class EventosTabla(tag: Tag) extends Table[EventosModelTable](tag, "eventos") with BaseTabla{

  override def id = column[Long]("id", O.PrimaryKey, O.AutoInc)
  def idCliente = column[Long]("id_cliente")
  def idPlan = column[Option[Long]]("id_plan")
  def idServicio = column[Option[Long]]("id_servicio")
  def tipo = column[TipoEventos.Value]("tipo_evento")
  def fechaInicio = column[DateTime]("fecha_inicio")
  def fechaFin = column[Option[DateTime]]("fecha_fin")

  def * = (id.?,idCliente.?,idPlan,idServicio,tipo,fechaInicio,fechaFin) <> (EventosModelTable.tupled, EventosModelTable.unapply _)

  def cliente = foreignKey("cliente",idCliente,TableQuery[ClientesTabla])(_.id)
  def plan = foreignKey("plan",idPlan,TableQuery[PlanesTabla])(_.id)
}

然后.. 我需要找到事件的 fechaFin 为 Null 或 fechaFin> DateTime.now... 但问题是 fechaFin 可以是 Null 然后是一个 Option 值,我无法与 DateTime.now 进行比较。编译错误是 Some[DateTime] 没有 > 方法。

我将不胜感激

查询如下..

def getAltasBajas(id : Long) : DBIOAction[Seq[EventosModelTable],NoStream,Effect.All] = {

      val q = for {
        altasBajas <- tabla.filter(_.idCliente === id)
            if altasBajas.fechaFin.isEmpty || (altasBajas.fechaFin.isDefined && (altasBajas.fechaFin)<(DateTime.now))
      }yield altasBajas

      q.result
    }

最佳答案

我找到了这个 answer这表明您的实现应该有效(至少据我所知)或者您可以尝试

val q = for {
  altasBajas <- tabla.filter(_.idCliente === id)
  if !altasBajas.fechaFin.isNull || altasBajas.fechaFin < DateTime.now
} yield altasBajas

关于scala - 如何在 slick 3.0 的过滤器上比较 column[option[DateTime] 与 DateTime.now,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31578579/

相关文章:

c# - DateTime.Parse 如果为 null,则采用最小日期值

scala - 使用 Slick 3.1.x 将数据库连接返回到 HikariCP 池

scala - Custom Slick Codegen 在 `${container} trait` 之外生成映射的案例类?

scala - 隐式类也可以是动态的吗?

java - JPA如何推断属性的数据类型

scala - 在 Scala 中什么时候应该使用 Array,什么时候应该使用 ArrayBuffer?

database - 检查 slick 3.0 中的表是否存在

java - 是否有用于使用 Scala 或 Java 编辑 MP4 元数据的库?

c# - DateTime 可选参数的默认值应该是多少?

python - Pandas 日期时间给出错误的输出