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

Seb*_*oli 1 go mongodb 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)
Run Code Online (Sandbox Code Playgroud)

我有这个辅助功能:

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

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 (
    )
)
Run Code Online (Sandbox Code Playgroud)

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

thw*_*hwd 5

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

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

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

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

编辑:

要使用mgo驱动程序从Go调用存储过程,请使用mgo.Database类型的Run()方法(直接链接),并eval使用要在服务器端执行的Javascript代码作为参数发出命令.就像是:

db.Run(bson.M{"eval": "myStoredFunction();"})
Run Code Online (Sandbox Code Playgroud)

代码未经测试

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