我想让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而不是插入?
答案 0 :(得分:5)
请参阅MongoDB文档中的以下URL:
有一个名为
system.js
的特殊系统集合,可以存储要重用的JavaScript函数。
但请注意,服务器端代码(相当于存储过程)的支持和性能仍然有点差(链接中的详细信息)。
修改:
要使用mgo driver使用mgo.Database
类型的Run()
方法(direct link)从Go调用存储过程,并使用Javascript发出eval
命令作为参数在服务器端执行的代码。类似的东西:
db.Run(bson.M{"eval": "myStoredFunction();"})
代码未经测试
无法在MongoDB insert
语句中评估代码。