db.insert(doc, callback)
作用:
插入文檔數(shù)據(jù)(文檔相當(dāng)于mysql表中的一條記錄)。如果文檔不包含_id字段,NeDB會(huì)自動(dòng)生成一個(gè),該字段是16個(gè)字符長(zhǎng)度的數(shù)字字符串。該字段一旦確定,就不能被更改。
參數(shù):
doc: 支持String, Number, Boolean, Date, null, array以及object類(lèi)型。如果該字段是undefined類(lèi)型,將不會(huì)被保存,這里和MongoDB處理方式有點(diǎn)不同,MongoDB會(huì)將undefined轉(zhuǎn)換為null進(jìn)行存儲(chǔ)。字段名稱(chēng)不能以"$"開(kāi)始,也不能包含"."。
callback(可選): 回調(diào)函數(shù),包含參數(shù)err以及newDoc,err是報(bào)錯(cuò),newDoc是新插入的文檔,包含它的_id字段。
示例
var doc = { hello: 'world'
, n: 5
, today: new Date()
, nedbIsAwesome: true
, notthere: null
, notToBeSaved: undefined // 該字段不會(huì)被保存
, fruits: [ 'apple', 'orange', 'pear' ]
, infos: { name: 'nedb' }
};
db.insert(doc, function (err, newDoc) { // Callback is optional
// newDoc is the newly inserted document, including its _id
// newDoc has no key called notToBeSaved since its value was undefined
});
// 使用array,實(shí)現(xiàn)批量插入。一旦其中一個(gè)操作失敗,所有改變將會(huì)回滾。
db.insert([{ a: 5 }, { a: 42 }], function (err, newDocs) {
// Two documents were inserted in the database
// newDocs is an array with these documents, augmented with their _id
});
// 如果a字段有唯一性約束,該操作將會(huì)執(zhí)行失敗。
db.insert([{ a: 5 }, { a: 42 }, { a: 5 }], function (err) {
// err is a 'uniqueViolated' error
// The database was not modified
});
更多建議: