9

我正在使用 Mongoid (v3) 访问 MongoDB,并希望执行此操作:

db.sessionlogs.update( 
    {sessionid: '12345'}, /* selection criteria */
    {'$push':{rows: "new set of data"}},  /* modification */
    true /* upsert */
);

这在 mongo shell 中运行良好。这也正是我想要的,因为它是一个单一的原子操作,这对我来说很重要,因为我会经常称呼它。我不想做两个操作——一个获取然后一个更新。我已经通过 mongoid 尝试了很多东西,但无法让它工作。

如何让 MongoID 不碍事,只需将此命令发送到 MongoDB?我猜想在 Moped 级别有一些方法可以做到这一点,但该库的文档基本上不存在。

4

3 回答 3

10

[在写问题时找到答案...]

criteria = Sessionlogs.collection.find(:sessionid => sessionid)
criteria.upsert("$push" => {"rows" => datarow})
于 2012-07-18T17:39:39.363 回答
2

这是一种方法:

session_log = SessionLog.new(session_id: '12345')
session_log.upsert
session_log.push(:rows, "新数据集")

或其他:

SessionLog.find_or_create_by(session_id: '12345')。
  push(:rows, "新数据集")

#push$push在场上执行原子操作。它在 原子持久性页面上进行了解释。

(注意:示例使用 UpperCamelCase 和 snake_case 与 Ruby 约定一样。)

于 2012-07-28T05:03:38.670 回答
0

暂时不要继续使用轻便摩托车,您可以使用查找和修改操作来实现相同的目的(使用所有默认范围和继承的好东西)

如果不存在,则在图中保存边的示例

edge = {source_id: session[:user_id],dest_id:product._id, name: edge_name}
ProductEdge.where(edge).find_and_modify(ProductEdge.new(edge).as_document,{upsert:true})
于 2014-01-04T19:36:51.027 回答