1

我的数据库看起来像

[
  {
    name: "domenic",
    records: {
      today: 5,
      yesterday: 1.5
    }
  },
  {
    name: "bob",
    records: { ... }
  }
]

当我尝试像这样的查询时

val result: Option[DBObject] = myCollection.findOne(
  MongoDBObject("name" -> "domenic")
  MongoDBObject("records" -> 1),
)

val records = result.get.getAs[BasicDBObject]("records").get
grater[Map[String, Number]].asObject(records)

它失败了(在运行时!)

GRATER GLITCH - unable to find or instantiate a grater using supplied path name

REASON: Class scala.collection.immutable.Map is an interface

Context: 'global'
Path from pickled Scala sig: 'scala.collection.immutable.Map'

我想我可以通过创建一个唯一字段是 a 的案例类Map[String, Number]然后获取它的属性来完成这项工作。这真的有必要吗?

4

1 回答 1

0

grater不将集合作为类型参数,只有案例类或特征/抽象类,其具体表示是案例类。由于您只是在查询地图,因此只需从DBObjectusing中提取您需要的值getAs[T]

Number可能不是 Salat 中受支持的类型 - 我当然从未尝试过。如果您需要Number,您可以编写自定义转换器或发送拉取请求以向 Salat 添加真正的支持。

于 2014-02-08T03:26:14.967 回答