2012-04-13 55 views
0

我想从Casbah的MongoCollectionBase.find(...)返回的DBObject中提取某个键“orderItems”的值。我有解决方案,但我不满意。我发现我的解决方案繁琐。它将每个步骤中从DBObject.toMap返回的java.util.Map转换并转换为Scala Map或其他集合。有什么更好的办法呢?由于使用Scala/Casbah从MongoDB DBObject提取值

val orders = provisioningDb("systems").find(MongoDBObject.empty, MongoDBObject("company.department.orders" -> 1)) 

import scala.collection.JavaConversions._ 

def findC(m : Map[String, Any]) : Iterable[Any] = { 
    val c = for ((k, v) <- m) yield (k, v) match { 
    case (k, v) if k equals "orderItems" => v 
    case (k, v : java.util.HashMap[String, Any]) => findC(toMap(v).asInstanceOf[Map[String, Any]]).head 
    case _ => Nil 
    } 
    c.filter(_.isInstanceOf[java.util.List[Any]]) 
} 

def toMap[K, E](m: java.util.Map[K, E]): Map[K, E] = { 
    Map.empty ++ new MapWrapper[K, E](m) 
} 

val orderItems = for { 
    x <- orders 
} yield x 

for (y <- orderItems) { 
    println(findC(toMap(y.toMap).asInstanceOf[Map[String, Any]])) 
} 

去掉细节坚持MongoDB中的2行的样本数据,

company : {department : {orders -> [{"id" : "543", "quantity" : 2}, {"id" : "223", "quantity" : 21}, {"id" : "332", "quantity" : 3}] 


company : {department : {orders -> [{"id" : "222", "quantity" : 8}, {"id" : "663", "quantity" : 3] 

回答

0

您是否尝试过寻找到使用case classSalat一起?

你也可以检查这个伟大的presentation,特别是滑动#28它谈论SalatDAO,它允许你直接坚持和检索你的案例对象!