你可以使用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")
请注意,如果指定的键无法找到,as
会抛出异常。您可以使用getAs
,它会给您Option[A]
:
注意:as
在未找到key时会抛出异常。您可以使用getAs
方法获取Option[A]
类型的返回值:
obj.getAs[String]("title") match {
case Some(someStr) => ...
case None => ...
}
提取列表要稍微复杂一些:
val myListOfInts =
(List() ++ obj("nums").asInstanceOf[BasicDBList]) map { _.asInstanceOf[Int] }
我写了一个帮助程序,可以使使用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"
我希望它能帮到你。
val obj = coll.findOne(query); val str = obj.getAs[String]("myValue")
时,我会收到value getAs is not a member of Option[coll.T]
的错误提示。 - Kevin MeredithfindOne
返回一个Option
类型。 - andyczerwonka