1

我正在尝试将现有的应用程序从 SQueryl 0.9.5 迁移到 0.9.6,以便使用新的扩展字段类型。我现在已经到了可以编译应用程序及其测试的地步,但是当我尝试加载Schema.

相当长的堆栈跟踪的一部分包括:

[error] ModelSpec.withDB(ModelSpec.scala:14)
[error] BucketSpec$$anonfun$1$$anonfun$apply$1.apply(BucketSpec.scala:11)
[error] BucketSpec$$anonfun$1$$anonfun$apply$1.apply(BucketSpec.scala:11)
[error] Usupported native type models.fields.DateTime,models.fields.DateTime
[error] class java.util.UUID -> java.util.UUID --> null
[error] class java.lang.String -> java.lang.String --> null
[error] class scala.Enumeration$Value -> scala.Enumeration.Val --> null
[error] class [B -> byte[] --> null
[error] class java.lang.Float -> java.lang.Float --> null
[error] class java.util.Date -> java.util.Date --> null
[error] class scala.Enumeration$Val -> scala.Enumeration.Val --> null
[error] class java.lang.Integer -> java.lang.Integer --> null
[error] class java.lang.Double -> java.lang.Double --> null
[error] class java.sql.Timestamp -> java.sql.Timestamp --> null
[error] class java.lang.Byte -> java.lang.Byte --> null
[error] class java.lang.Boolean -> java.lang.Boolean --> null
[error] class scala.math.BigDecimal -> scala.math.BigDecimal --> null
[error] class java.lang.Long -> java.lang.Long --> null
[error] org.squeryl.internals.Utils$.throwError(Utils.scala:95)
[error] org.squeryl.internals.FieldMapper$$anonfun$get$1.apply(FieldMapper.scala:299)
[error] org.squeryl.internals.FieldMapper$$anonfun$get$1.apply(FieldMapper.scala:299)

看一下源码好像异常来自FieldMapper.lookup方法的失败,即行

if(!c.isPrimitive)
  registry.get(c)

据我了解,类的映射是通过该register方法加载的,特别是对于本机类型,我们有这些行

  protected def initialize {
    import PrimitiveTypeSupport._

    register(byteTEF)
    register(intTEF)
    register(longTEF)
    register(floatTEF)
    register(doubleTEF)
    register(bigDecimalTEF)

    register(binaryTEF)
    register(booleanTEF)
    register(stringTEF)
    register(timestampTEF)
    register(dateTEF)
    register(uuidTEF)

我不确定如何在此注册表中加载我的个人扩展原语类型,以便正确使用它们。

有谁知道我应该启用扩展原始类型的机制是什么?

编辑:

这是我的模型-在我看来,它看起来像“官方”示例,除了我没有直接使用 Joda time 而是使用它周围的薄包装,这被称为DateTime

object DateTime extends PrimitiveTypeMode {
  import org.squeryl._
  import org.squeryl.dsl._

  implicit val timeTEF = new NonPrimitiveJdbcMapper[Long, DateTime, TLong](longTEF, this) {
    def convertFromJdbc(t: Long) = DateTime(t)
    def convertToJdbc(t: DateTime) = t.timestamp
  }

  implicit val optionTimeTEF =
    new TypedExpressionFactory[Option[DateTime], TOptionLong]
      with DeOptionizer[Long, DateTime, TLong, Option[DateTime], TOptionLong] {

    val deOptionizer = timeTEF
  }

  implicit def timeToTE(s: DateTime) = timeTEF.create(s)

  implicit def optionTimeToTE(s: Option[DateTime]) = optionTimeTEF.create(s)
}
4

1 回答 1

1

更正答案:

您正在导入 org.squeryl.PrimitiveTypeMode 伴随对象以及您自己的扩展(对象 DateTime 扩展 PrimitiveTypeMode)

您只能在同一应用程序中使用 on 或 other(请参阅http://squeryl.org/0.9.6.html

现在不推荐使用 org.squeryl.PrimitiveTypeMode 伴生对象(不推荐使用同名特征)

旧(错误)答案:

您不需要注册您的自定义类型,该注册仅适用于原始 JDBC 类型,它是一个封闭集。

请参阅此示例:https ://github.com/max-l/squeryl-extended-field-types-example JodaDate 由(已注册的)Timestamp 原始类型支持。

于 2012-12-19T14:05:18.093 回答