7

好的,这是关于 Casbah 和 MongoDB 基础知识的另一个问题。从数据库中检索 DBObject 后,如何从中提取某些数据?我知道有DBObject.get()返回的方法java.lang.Object。我是否必须这样做,然后将数据转换为所需的类型?我不确定这是不是最好的方法......有人可以推荐如何更好地做到这一点吗?

更新:

最后我采用了手动处理所有东西的方式。由于案例类的限制,我没有使用 Salat,因为不建议将案例类用于生孩子,这需要重新安排架构。但是,该答案被标记为最佳答案,因为它适用于大多数情况,并且这里没有其他更通用的答案。

4

2 回答 2

11

您可以使用 MongoDBObject 的as方法来获取值并将其转换为一次调用:

val coll = MongoConnection()(dbName)(collName)
val query = MongoDBObject("title" -> "some value")
val obj = coll findOne query

val someStr = obj.as[String]("title")
val someInt = obj.as[Int]("count")
// and so on..

请注意,as如果找不到给定的键,则会引发异常。您可以使用getAswhich 为您提供Option[A]

obj.getAs[String]("title") match {
    case Some(someStr) => ...
    case None => ...
}

提取列表有点复杂:

val myListOfInts =
  (List() ++ obj("nums").asInstanceOf[BasicDBList]) map { _.asInstanceOf[Int] }

我写了一个 helper,让使用 casbah 更加简洁,可能会有帮助,所以附上:

package utils

import com.mongodb.casbah.Imports._

class DBObjectHelper(underlying: DBObject) {

  def asString(key: String) = underlying.as[String](key)

  def asDouble(key: String) = underlying.as[Double](key)

  def asInt(key: String) = underlying.as[Int](key)

  def asList[A](key: String) =
    (List() ++ underlying(key).asInstanceOf[BasicDBList]) map { _.asInstanceOf[A] }

  def asDoubleList(key: String) = asList[Double](key)
}

object DBObjectHelper {

  implicit def toDBObjectHelper(obj: DBObject) = new DBObjectHelper(obj)

}

您可以像这样使用助手:

val someStr = obj asString "title"
val someInt = obj asInt "count"
val myDoubleList = obj asDoubleList "coords"

我希望它会帮助你。

于 2012-06-26T03:41:18.940 回答
2

如果您不害怕使用其他依赖项,请使用Salat。使用 Salat,将案例类转换为数据库对象并返回非常简单。

序列化

val dbo = grater[Company].asDBObject(company)

反序列化

val company_* = grater[Company].asObject(dbo)
于 2012-05-06T11:33:21.730 回答