2012-05-06 33 views
7

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

UPDATE:

最后我去手动处理所有的东西的方式。由于案例类的限制,我没有使用萨拉特语,因为不建议案例类有孩子,而且需要进行架构重新安排。但是,答案被标记为最佳答案,因为它在大多数情况下都可以工作,并且在这里没有其他更一般的答案。

回答

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将引发异常给定的密​​钥无法找到。您可以使用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" 

我希望它能帮助你。

+0

哇,涵盖了这个话题非常好!谢谢,这显然现在被选为最佳答案。 – noncom

+0

当调用val obj = coll.findOne(query)时,我得到'value getAs不是Option [coll.T]的成员'; val str = obj.getAs [String](“myValue”)'。 –

+0

该示例不起作用,'findOne'返回'Option'类型。 – andyczerwonka

2

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

系列化

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

反序列化

val company_* = grater[Company].asObject(dbo) 
+0

是的,我知道萨拉......不害怕使用依赖关系,但只有案例级别的需求可能会带来一些麻烦。如果没有其他有意义的答案,我将不得不考虑萨拉特,然后......但是案例班可能需要改变架构。 – noncom

+0

它不适用于斯卡拉2.10 – expert

相关问题