我怎样才能让MongoDB评估一些JavaScript以获得字段的价值?

时间:2012-08-17 15:42:51

标签: mongodb go mgo

我想让MongoDB动态地为我正在插入的文档的一个字段赋值。例如:来自MongoDB服务器的当前时间就像NOW()在MySQL中一样。

我试过了:

c := mongoSession.DB("myapp").C("instances")
rand.Seed(time.Now().UnixNano())
err := c.Insert(
   struct{Serial, Priority, Url, LastSeen interface{}}{ 
      Url: getInformedHost() + ":" + getRunningPortString(), 
      Priority: rand.Int(), 
      LastSeen: mongoNow() }
)
checkError(err, "Could not register on MongoDB server.", 3)

我有这个辅助功能:

func mongoNow() bson.JavaScript {
    return bson.JavaScript{Code: 
         "(new Date()).ISODate('YYYY-MM-DD hh:mm:ss')"}
}

LastSeen字段存储为脚本而不是评估:

[_id] => MongoId Object (
    [$id] => 502d6f984eaead30a134fa10
)
[priority] => 1694546828
[url] => 127.0.0.1:8080
[lastseen] => MongoCode Object (
    [code] => (new Date()).ISODate('YYYY-MM-DD hh:mm:ss')
    [scope] => Array (
    )
)

如何评估一些javascript而不是插入?

1 个答案:

答案 0 :(得分:5)

请参阅MongoDB文档中的以下URL:

http://www.mongodb.org/display/DOCS/Server-side+Code+Execution#Server-sideCodeExecution-Storingfunctionsserverside

  

有一个名为system.js的特殊系统集合,可以存储要重用的JavaScript函数。

但请注意,服务器端代码(相当于存储过程)的支持和性能仍然有点差(链接中的详细信息)。

修改:

要使用mgo driver使用mgo.Database类型的Run()方法(direct link)从Go调用存储过程,并使用Javascript发出eval命令作为参数在服务器端执行的代码。类似的东西:

db.Run(bson.M{"eval": "myStoredFunction();"})

代码未经测试

无法在MongoDB insert语句中评估代码。