MongoDB - Inserisci documento

In questo capitolo impareremo come inserire un documento nella raccolta MongoDB.

Il metodo insert ()

Per inserire dati nella raccolta di MongoDB, è necessario utilizzare MongoDB insert() o save() metodo.

Sintassi

La sintassi di base di insert() il comando è il seguente:

>db.COLLECTION_NAME.insert(document)

Esempio

> db.users.insert({
... _id : ObjectId("507f191e810c19729de860ea"),
... title: "MongoDB Overview",
... description: "MongoDB is no sql database",
... by: "tutorials point",
... url: "http://www.tutorialspoint.com",
... tags: ['mongodb', 'database', 'NoSQL'],
... likes: 100
... })
WriteResult({ "nInserted" : 1 })
>

Qui mycolè il nome della nostra collezione, come creato nel capitolo precedente. Se la raccolta non esiste nel database, MongoDB creerà questa raccolta e quindi inserirà un documento al suo interno.

Nel documento inserito, se non specifichiamo il parametro _id, MongoDB assegna un ObjectId univoco per questo documento.

_id è un numero esadecimale di 12 byte univoco per ogni documento in una raccolta. 12 byte sono suddivisi come segue:

_id: ObjectId(4 bytes timestamp, 3 bytes machine id, 2 bytes process id, 3 bytes incrementer)

Puoi anche passare un array di documenti nel metodo insert () come mostrato di seguito :.

> db.createCollection("post")
> db.post.insert([
	{
		title: "MongoDB Overview",
		description: "MongoDB is no SQL database",
		by: "tutorials point",
		url: "http://www.tutorialspoint.com",
		tags: ["mongodb", "database", "NoSQL"],
		likes: 100
	},
	{
	title: "NoSQL Database",
	description: "NoSQL database doesn't have tables",
	by: "tutorials point",
	url: "http://www.tutorialspoint.com",
	tags: ["mongodb", "database", "NoSQL"],
	likes: 20,
	comments: [
		{
			user:"user1",
			message: "My first comment",
			dateCreated: new Date(2013,11,10,2,35),
			like: 0
		}
	]
}
])
BulkWriteResult({
	"writeErrors" : [ ],
	"writeConcernErrors" : [ ],
	"nInserted" : 2,
	"nUpserted" : 0,
	"nMatched" : 0,
	"nModified" : 0,
	"nRemoved" : 0,
	"upserted" : [ ]
})
>

Per inserire il documento puoi usare db.post.save(document)anche. Se non specifichi_id nel documento quindi save() metodo funzionerà come insert()metodo. Se si specifica _id, sostituirà tutti i dati del documento contenente _id come specificato nel metodo save ().

Il metodo insertOne ()

Se è necessario inserire un solo documento in una raccolta, è possibile utilizzare questo metodo.

Sintassi

La sintassi di base del comando insert () è la seguente:

>db.COLLECTION_NAME.insertOne(document)

Esempio

L'esempio seguente crea una nuova raccolta denominata empDetails e inserisce un documento utilizzando il metodo insertOne ().

> db.createCollection("empDetails")
{ "ok" : 1 }
> db.empDetails.insertOne(
	{
		First_Name: "Radhika",
		Last_Name: "Sharma",
		Date_Of_Birth: "1995-09-26",
		e_mail: "[email protected]",
		phone: "9848022338"
	})
{
	"acknowledged" : true,
	"insertedId" : ObjectId("5dd62b4070fb13eec3963bea")
}
>

Il metodo insertMany ()

È possibile inserire più documenti utilizzando il metodo insertMany (). A questo metodo è necessario passare una serie di documenti.

Esempio

L'esempio seguente inserisce tre diversi documenti nella raccolta empDetails utilizzando il metodo insertMany ().

> db.empDetails.insertMany(
	[
		{
			First_Name: "Radhika",
			Last_Name: "Sharma",
			Date_Of_Birth: "1995-09-26",
			e_mail: "[email protected]",
			phone: "9000012345"
		},
		{
			First_Name: "Rachel",
			Last_Name: "Christopher",
			Date_Of_Birth: "1990-02-16",
			e_mail: "[email protected]",
			phone: "9000054321"
		},
		{
			First_Name: "Fathima",
			Last_Name: "Sheik",
			Date_Of_Birth: "1990-02-16",
			e_mail: "[email protected]",
			phone: "9000054321"
		}
	]
)
{
	"acknowledged" : true,
	"insertedIds" : [
		ObjectId("5dd631f270fb13eec3963bed"),
		ObjectId("5dd631f270fb13eec3963bee"),
		ObjectId("5dd631f270fb13eec3963bef")
	]
}
>