0

我正在尝试实现以下目标:基本上只是处理一个 mongodb 文档并向其添加一个时间戳字段,以重建文档被更改的顺序,并在需要时恢复这些条目。

我的方法如下:

@Salat
trait Version[A <: DBEntity] extends ModelCompanion[A, ObjectId] {

  def timeStamp: Long = System.currentTimeMillis()

  /**
   * this method overrides the default salat dao save method in order to make a     copy    for versioning of Objects
   */
  override def save(entity: A) =
    {
      if (entity.id != null) {
        // let salat deserialze the case class into a DBObject
        val dbo = dao._grater.asDBObject(entity)
        //convert the Object into a Map and append our timestamp
        val builder = BasicDBObjectBuilder.start(dbo.toMap()).add("timeStamp", timeStamp)
        val copyCollection = MongoDBLayer.mongoDB("history")
        //and save it in the historic collection
        copyCollection.insert(builder.get())
      }
      //delegate to the superclass to perform the actual save process
      val wr = dao.save(entity)
      wr

    }
}

有没有更优雅/方便的方式来做到这一点?

或者你的方法是怎样的?

提前致谢,

斯特凡

4

1 回答 1

0

请参阅SalatDAO#decorateDBO- 在每次插入/保存/更新之前调用此方法。这可能是一个合理的地方,可以停放将时间戳添加到 DBO 并将副本保存在历史集合中的代码。只需覆盖它并在开头调用 super.decorateDBO 即可。然后继续添加您的时间戳并执行您需要做的任何其他事情。

   /** A central place to modify DBOs before inserting, saving, or updating.
    *  @param toPersist object to be serialized
    *  @return decorated DBO for persisting
    */
   def decorateDBO(toPersist: ObjectType) = {
     val dbo = _grater.asDBObject(toPersist)
     if (forceTypeHints) {
       // take advantage of the mutability of DBObject by cramming in a type hint
       dbo(ctx.typeHintStrategy.typeHint) = ctx.typeHintStrategy.encode(toPersist.getClass.getName).asInstanceOf[AnyRef]
     }
     dbo
   }

(DBO 也是可变的,因此无需调用toMap。您可以直接将时间戳分配给dbo("timestamp")

于 2013-09-17T03:51:37.787 回答