我是一个scala新手,一直在试图为我的应用程序开发DAO层。以下代码段概述了模型对象结构及其关联的数据访问对象。
// Model object base class
abstract class Model[M <: Model[M]] {
val dao: Dao[M]
}
// DAO for each model object, with find, delete, update
abstract class Dao[M <: Model[M]] {
// meta data describing the model object
case class Column(val name:String, val get: M => _)
val columns : Map[String,Column]
}
以下是模型及其相关DAO的具体用法。
// example simple model object with it's DAO
case class ItemModel (val name:String) extends Model[ItemModel] {
val dao = ItemDao
}
object ItemDao extends Dao[ItemModel] {
val columns = Map("name" -> Column("name", { v:ItemModel => v.name}))
}
现在,当我使用模型对象并直接关联DAO时,生活就很好。
object Works {
// normal access pattern
def good1(value: ItemModel) = value.name
// even through the DAO
def good2(value: ItemModel) = value.dao.columns("name").get(value)
}
问题是当我试图一般地访问一个对象时。在没有编译器抱怨的情况下,我无法获取传递Model值的方法签名。
// Trouble trying to manipulate base model objects
object Trouble {
// type mismatch; found : value.type (with underlying type test.Model[_]) required: _$2 where type _$2 Test.scala
def bad1(value: Model[_]) = value.dao.columns("name").get(value)
// type mismatch; found : value.type (with underlying type test.Model[_ <: test.Model[_]]) required: _$3 where type _$3 <: test.Model[_]
def bad2(value: Model[_ <: Model[_]]) = value.dao.columns("name").get(value)
// type mismatch; found : value.type (with underlying type X forSome { type X <: models.Model[X] }) required: X where type X <: models.Model[X]
def bad3(value: X forSome {type X <: Model[X]}) = value.dao.columns("name").get(value)
}
非常感谢任何帮助或指示。
答案 0 :(得分:4)
在所有不良例程中,值的类型为Model
,但get
的{{1}}需要Column
。
你可以这样做:
M
当你不需要它们时避免存在类型,它们使事情变得更复杂。此外,您的def good[M <: Model[M]](value: M) = value.dao.columns("name").get(value)
也可能是Column.get
;对于协方差,它不会对允许哪些功能施加任何限制。