我最近开始为MongoDB使用Scala、Akka和Salat序列化库。现在,我正尝试为如下对象设置一个SalatDAO:
import com.novus.salat.annotations._
case class MyObject(@Key("_id) compId: MyCompositeId, value: String)
case class MyCompositeId(x: String, y: String)我创建了一个DAO,如下所示:
import com.novus.salat.global._
import com.novus.salat.dao._
import com.mongodb.casbah.{MongoURI, MongoConnection}
import com.mongodb.casbah.commons.MongoDBObject
class MyObjectDAO(uri: String, db: String, coll: String)
extends SalatDAO[MyObject, MyCompositeId](MongoConnection(MongoURI(uri))(db)(coll))最后,我编写了一个简单的单元测试:
val dao = new MyObjectDAO(...)
val id = new MyCompositeId("some","key)
// works fine
dao.findOne(MongoDBObject("_id.x" -> id.x, "_id.y" -> id.y))
// does NOT work
dao.findOneById(id)第一个调用将返回Some(_),而第二个调用将返回None。
现在,我查看了findOneById的源代码,试图理解为什么它不起作用:
/** @param id identifier
* @return (Option[ObjectType]) Some() of the object found,
* or <code>None</code> if no such object exists
*/
def findOneById(id: ID) =
collection.findOneByID(id.asInstanceOf[AnyRef]).map(_grater.asObject(_))在我看来,它闻起来很像一个bug :这个方法是将一个MyCompositeId类型的对象传递给MyCompositeId,而Casbah驱动程序并不理解这个对象。我认为Salat应该在传递对象之前将该对象序列化为MongoDBObject。
我说的对吗?这是个虫子吗?还是我错过了什么?
谢谢
发布于 2013-11-21 16:54:26
关于Salat项目票的讨论:https://github.com/novus/salat/issues/110
发布于 2013-11-21 16:19:00
事实证明,复合密钥不受Salat的正式支持,更确切地说,它们只是部分支持。实际上,以下代码起作用:
dao.insert(new MyObject(new MyCompositeId("some","key"), "my data")也就是说,使用复合键正确地创建MongoDB中的记录:
db.coll.find()
{ "_id" : { "x" : "some", "y" : "key" }, "value" : "my data" }https://stackoverflow.com/questions/20125785
复制相似问题