您可以使用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
將引發異常給定的密鑰無法找到。您可以使用getAs
,讓你Option[A]
:
obj.getAs[String]("title") match {
case Some(someStr) => ...
case None => ...
}
提取列表是一個比較複雜一點:
val myListOfInts =
(List() ++ obj("nums").asInstanceOf[BasicDBList]) map { _.asInstanceOf[Int] }
我寫了一個幫手,這使得使用卡斯巴更consice,可能會有幫助,所以我將其附加:
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"
我希望它能幫助你。
哇,涵蓋了這個話題非常好!謝謝,這顯然現在被選爲最佳答案。 – noncom
當調用val obj = coll.findOne(query)時,我得到'value getAs不是Option [coll.T]的成員'; val str = obj.getAs [String](「myValue」)'。 –
該示例不起作用,'findOne'返回'Option'類型。 – andyczerwonka