一尘不染

我如何要求MongoDB评估一些JavaScript以获得字段的价值?

go

我想让MongoDB动态为我要插入的文档的字段之一分配一个值。例如:MongoDB服务器的当前时间就像MySQL中的NOW()一样。

我尝试了这个:

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评估而不是插入?


阅读 208

收藏
2020-07-02

共1个答案

一尘不染

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

http://www.mongodb.org/display/DOCS/Server-side+Code+Execution#Server-
sideCodeExecution-存储功能服务器端

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

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

编辑:

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

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

未经测试的代码

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

2020-07-02