Evaluating JavaScript in MongoDB to Assign Field Values
Inserting documents into a MongoDB collection can be augmented with JavaScript evaluation to dynamically assign field values. However, the code given initially fails to evaluate the JavaScript statement and instead stores it as a script.
The MongoDB documentation outlines a method for storing JavaScript functions server-side in the system.js collection. By creating a stored function, we can evaluate JavaScript remotely from the Go client.
Method using Stored Functions:
db.system.js.insert({ _id: "assignDate", value: function() { return ISODate(); } });
func createInstance(c *mgo.Collection) { result, err := c.Run( bson.M{"eval": "assignDate()"}, ) checkError(err, "Could not get server time") var doc bson.M err = result.One(&doc) if err != nil { checkError(err, "Invalid result from stored function", 3) } lastSeen, ok := doc["retval"].(time.Time) if !ok { checkError(fmtErrorf("Invalid result from stored function: %v", doc["retval"]), "Invalid result from stored function: %v", 3) } // ... Insert document with evaluated field value }
Considerations:
The above is the detailed content of How Can I Use Stored JavaScript Functions in MongoDB to Dynamically Assign Field Values?. For more information, please follow other related articles on the PHP Chinese website!