我有一个与我正在使用的MongoDB集合类型匹配的结构:
type AppInstance struct { Id bson.ObjectId "_id,omitempty" Url string Priority int LastSeen string }
我希望LastSeen字段保存与该特定应用程序的最后一次交互的时间。因此,应用程序会自行注册以设置当前时间(以字符串形式)。
我想要的是Mongo在插入时动态地将自己的当前时间设置到该字段中,就像MySQL的NOW()函数一样。
我有这个辅助功能:
func mongoNow() bson.JavaScript { return bson.JavaScript{Code: "return (new Date()).ISODate('YYYY-MM-DD hh:mm:ss');"} }
我尝试了这个:
c := mongoSession.DB("myapp").C("instances") rand.Seed(time.Now().UnixNano()) err := c.Insert( struct{Id, Serial, Priority, Url, LastSeen interface{}}{ Id: bson.NewObjectId(), Url: getInformedHost() + ":" + getRunningPortString(), Priority: rand.Int(), LastSeen: mongoNow() } ) checkError(err, "Could not register on MongoDB server.", 3)
LastSeen字段存储为脚本而不是评估:
[_id] => MongoId Object ( [$id] => 502d6f984eaead30a134fa10 ) [id] => MongoId Object ( [$id] => 502d6f98aa443e0ffd000001 ) [priority] => 1694546828 [url] => 127.0.0.1:8080 [lastseen] => MongoCode Object ( [code] => (new Date()).ISODate('YYYY-MM-DD hh:mm:ss') [scope] => Array ( ) )
因此,我认为存在一些问题:
首先,如何插入当前时间?
其次,如何获取一些经过评估而不是插入的JavaScript?
对第二个答案的答案可能足以回答第一个答案,但也可能并非如此。
不要将时间存储为字符串。mgo支持time.Time,它类似于DateJavascript中的对象:
Date
type Event struct { Id bson.ObjectId "_id,omitempty" Which string Date time.Time }
插入一个现在发生的事件:
e := Event{ Which: "first event", Date: time.Now(), } c.Insert(e)