Python MongoDB - Guide rapide
Pymongo est une distribution python qui fournit des outils pour travailler avec MongoDB, c'est le moyen le plus préféré de communiquer avec la base de données MongoDB à partir de python.
Installation
Pour installer pymongo, assurez-vous tout d'abord que vous avez correctement installé python3 (avec PIP) et MongoDB. Exécutez ensuite la commande suivante.
C:\WINDOWS\system32>pip install pymongo
Collecting pymongo
Using cached https://files.pythonhosted.org/packages/cb/a6/b0ae3781b0ad75825e00e29dc5489b53512625e02328d73556e1ecdf12f8/pymongo-3.9.0-cp37-cp37m-win32.whl
Installing collected packages: pymongo
Successfully installed pymongo-3.9.0
Vérification
Une fois que vous avez installé pymongo, ouvrez un nouveau document texte, collez-y la ligne suivante et enregistrez-le sous test.py.
import pymongo
Si vous avez correctement installé pymongo, si vous exécutez le test.py comme indiqué ci-dessous, vous ne devriez pas avoir de problèmes.
D:\Python_MongoDB>test.py
D:\Python_MongoDB>
Contrairement à d'autres bases de données, MongoDB ne fournit pas de commande distincte pour créer une base de données.
En général, la commande use est utilisée pour sélectionner / basculer vers la base de données spécifique. Cette commande vérifie initialement si la base de données que nous spécifions existe, si c'est le cas, elle s'y connecte. Si la base de données, que nous spécifions avec la commande use n'existe pas, une nouvelle base de données sera créée.
Par conséquent, vous pouvez créer une base de données dans MongoDB en utilisant le Use commander.
Syntaxe
Syntaxe de base de use DATABASE la déclaration est la suivante -
use DATABASE_NAME
Exemple
La commande suivante crée une base de données nommée dans mydb.
>use mydb
switched to db mydb
Vous pouvez vérifier votre création en utilisant la commande db , cela affiche la base de données actuelle.
>db
mydb
Créer une base de données à l'aide de Python
Pour vous connecter à MongoDB en utilisant pymongo, vous devez importer et créer un MongoClient, puis vous pouvez accéder directement à la base de données que vous devez créer dans l'attribut passion.
Exemple
L'exemple suivant crée une base de données dans MangoDB.
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['mydb']
print("Database created........")
#Verification
print("List of databases after creating new one")
print(client.list_database_names())
Production
Database created........
List of databases after creating new one:
['admin', 'config', 'local', 'mydb']
Vous pouvez également spécifier le port et les noms d'hôte lors de la création d'un MongoClient et accéder aux bases de données en style dictionnaire.
Exemple
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['mydb']
print("Database created........")
Production
Database created........
Une collection dans MongoDB contient un ensemble de documents, elle est analogue à une table dans des bases de données relationnelles.
Vous pouvez créer une collection à l'aide du createCollection()méthode. Cette méthode accepte une valeur String représentant le nom de la collection à créer et un paramètre options (facultatif).
En utilisant cela, vous pouvez spécifier ce qui suit -
La taille de la collection.
Le nombre maximal de documents autorisés dans la collection plafonnée.
Si la collection que nous créons doit être une collection plafonnée (collection de taille fixe).
Indique si la collection que nous créons doit être indexée automatiquement.
Syntaxe
Voici la syntaxe pour créer une collection dans MongoDB.
db.createCollection("CollectionName")
Exemple
La méthode suivante crée une collection nommée ExampleCollection.
> use mydb
switched to db mydb
> db.createCollection("ExampleCollection")
{ "ok" : 1 }
>
De même, voici une requête qui crée une collection à l'aide des options de la méthode createCollection ().
>db.createCollection("mycol", { capped : true, autoIndexId : true, size :
6142800, max : 10000 } )
{ "ok" : 1 }
>
Créer une collection à l'aide de Python
L'exemple python suivant se connecte à une base de données dans MongoDB (mydb) et crée une collection à l'intérieur.
Exemple
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['mydb']
#Creating a collection
collection = db['example']
print("Collection created........")
Production
Collection created........
Vous pouvez stocker des documents dans MongoDB en utilisant la méthode insert () . Cette méthode accepte un document JSON en tant que paramètre.
Syntaxe
Voici la syntaxe de la méthode d'insertion.
>db.COLLECTION_NAME.insert(DOCUMENT_NAME)
Exemple
> use mydb
switched to db mydb
> db.createCollection("sample")
{ "ok" : 1 }
> doc1 = {"name": "Ram", "age": "26", "city": "Hyderabad"}
{ "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
> db.sample.insert(doc1)
WriteResult({ "nInserted" : 1 })
>
De même, vous pouvez également insérer plusieurs documents à l'aide du insert() méthode.
> use testDB
switched to db testDB
> db.createCollection("sample")
{ "ok" : 1 }
> data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" },
{"_id": "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
]
[
{"_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad"},
{"_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore"},
{"_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai"}
]
> db.sample.insert(data)
BulkWriteResult({
"writeErrors" : [ ],
"writeConcernErrors" : [ ],
"nInserted" : 3,
"nUpserted" : 0,
"nMatched" : 0,
"nModified" : 0,
"nRemoved" : 0,
"upserted" : [ ]
})
>
Créer une collection à l'aide de Python
Pymongo fournit une méthode nommée insert_one () pour insérer un document dans MangoDB. Pour cette méthode, nous devons transmettre le document au format dictionnaire.
Exemple
L'exemple suivant insère un document dans la collection nommée example.
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['mydb']
#Creating a collection
coll = db['example']
#Inserting document into a collection
doc1 = {"name": "Ram", "age": "26", "city": "Hyderabad"}
coll.insert_one(doc1)
print(coll.find_one())
Production
{'_id': ObjectId('5d63ad6ce043e2a93885858b'), 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
Pour insérer plusieurs documents dans MongoDB en utilisant pymongo, vous devez appeler la méthode insert_many ().
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['mydb']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
print(res.inserted_ids)
Production
Data inserted ......
['101', '102', '103']
Vous pouvez lire / récupérer des documents stockés à partir de MongoDB en utilisant le find()méthode. Cette méthode récupère et affiche tous les documents de MongoDB de manière non structurée.
Syntaxe
Voici la syntaxe du find() méthode.
>db.COLLECTION_NAME.find()
Exemple
Supposons que nous ayons inséré 3 documents dans une base de données nommée testDB dans une collection nommée sample en utilisant les requêtes suivantes -
> use testDB
> db.createCollection("sample")
> data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" },
{"_id": "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
]
> db.sample.insert(data)
Vous pouvez récupérer les documents insérés en utilisant la méthode find () comme -
> use testDB
switched to db testDB
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
>
Vous pouvez également récupérer le premier document de la collection en utilisant la méthode findOne () comme -
> db.sample.findOne()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
Récupération de données (recherche) à l'aide de Python
le find_One() La méthode de pymongo est utilisée pour récupérer un seul document basé sur votre requête, en cas d'absence de correspondance, cette méthode ne renvoie rien et si vous n'utilisez aucune requête, elle retourne le premier document de la collection.
Cette méthode est pratique chaque fois que vous devez récupérer un seul document d'un résultat ou, si vous êtes sûr que votre requête ne renvoie qu'un seul document.
Exemple
Exemple de python suivant pour récupérer le premier document d'une collection -
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['mydatabase']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
print(res.inserted_ids)
#Retrieving the first record using the find_one() method
print("First record of the collection: ")
print(coll.find_one())
#Retrieving a record with is 103 using the find_one() method
print("Record whose id is 103: ")
print(coll.find_one({"_id": "103"}))
Production
Data inserted ......
['101', '102', '103']
First record of the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
Record whose id is 103:
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Pour obtenir plusieurs documents dans une seule requête (méthode de recherche d'appel unique), vous pouvez utiliser la find()méthode du pymongo. Si vous n'avez passé aucune requête, cela retourne tous les documents d'une collection et, si vous avez passé une requête à cette méthode, elle renvoie tous les documents correspondants.
Exemple
#Getting the database instance
db = client['myDB']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving all the records using the find() method
print("Records of the collection: ")
for doc1 in coll.find():
print(doc1)
#Retrieving records with age greater than 26 using the find() method
print("Record whose age is more than 26: ")
for doc2 in coll.find({"age":{"$gt":"26"}}):
print(doc2)
Production
Data inserted ......
Records of the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Record whose age is more than 26:
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Lors de la récupération à l'aide de find(), vous pouvez filtrer les documents à l'aide de l'objet de requête. Vous pouvez transmettre la requête en spécifiant la condition des documents requis en tant que paramètre à cette méthode.
Les opérateurs
Voici la liste des opérateurs utilisés dans les requêtes dans MongoDB.
Opération | Syntaxe | Exemple |
---|---|---|
Égalité | {"valeur clé"} | db.mycol.find ({"by": "tutorials point"}) |
Moins que | {"clé": {$ lt: "value"}} | db.mycol.find ({"aime": {$ lt: 50}}) |
Inférieur à égal | {"key": {$ lte: "value"}} | db.mycol.find ({"aime": {$ lte: 50}}) |
Plus grand que | {"clé": {$ gt: "value"}} | db.mycol.find ({"aime": {$ gt: 50}}) |
Supérieur à égal | {"key" {$ gte: "value"}} | db.mycol.find ({"aime": {$ gte: 50}}) |
Pas égal | {"key": {$ ne: "value"}} | db.mycol.find ({"aime": {$ ne: 50}}) |
Exemple 1
L'exemple suivant récupère le document dans une collection dont le nom est sarmista.
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['sdsegf']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
{"_id": "1004", "name": "Romeo", "age": "25", "city": "Pune"},
{"_id": "1005", "name": "Sarmista", "age": "23", "city": "Delhi"},
{"_id": "1006", "name": "Rasajna", "age": "26", "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving data
print("Documents in the collection: ")
for doc1 in coll.find({"name":"Sarmista"}):
print(doc1)
Production
Data inserted ......
Documents in the collection:
{'_id': '1005', 'name': 'Sarmista', 'age': '23', 'city': 'Delhi'}
Exemple2
L'exemple suivant récupère le document dans une collection dont la valeur d'âge est supérieure à 26.
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['ghhj']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
{"_id": "1004", "name": "Romeo", "age": "25", "city": "Pune"},
{"_id": "1005", "name": "Sarmista", "age": "23", "city": "Delhi"},
{"_id": "1006", "name": "Rasajna", "age": "26", "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving data
print("Documents in the collection: ")
for doc in coll.find({"age":{"$gt":"26"}}):
print(doc)
Production
Data inserted ......
Documents in the collection:
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Lors de la récupération du contenu d'une collection, vous pouvez les trier et les organiser par ordre croissant ou décroissant à l'aide du sort() méthode.
À cette méthode, vous pouvez passer le (s) champ (s) et l'ordre de tri qui est 1 ou -1. Où, 1 correspond à l'ordre croissant et -1 à l'ordre décroissant.
Syntaxe
Voici la syntaxe de la méthode sort () .
>db.COLLECTION_NAME.find().sort({KEY:1})
Exemple
Supposons que nous ayons créé une collection et y avons inséré 5 documents comme indiqué ci-dessous -
> use testDB
switched to db testDB
> db.createCollection("myColl")
{ "ok" : 1 }
> data = [
... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
... {"_id": "1002", "name": "Rahim", "age": 27, "city": "Bangalore"},
... {"_id": "1003", "name": "Robert", "age": 28, "city": "Mumbai"},
... {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
... {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
... {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
> db.sample.insert(data)
BulkWriteResult({
"writeErrors" : [ ],
"writeConcernErrors" : [ ],
"nInserted" : 6,
"nUpserted" : 0,
"nMatched" : 0,
"nModified" : 0,
"nRemoved" : 0,
"upserted" : [ ]
})
La ligne suivante récupère tous les documents de la collection qui sont triés par ordre croissant en fonction de l'âge.
> db.sample.find().sort({age:1})
{ "_id" : "1005", "name" : "Sarmista", "age" : 23, "city" : "Delhi" }
{ "_id" : "1004", "name" : "Romeo", "age" : 25, "city" : "Pune" }
{ "_id" : "1006", "name" : "Rasajna", "age" : 26, "city" : "Chennai" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
Trier les documents à l'aide de Python
Pour trier les résultats d'une requête par ordre croissant ou décroissant, pymongo fournit le sort()méthode. À cette méthode, transmettez une valeur numérique représentant le nombre de documents dont vous avez besoin dans le résultat.
Par défaut, cette méthode trie les documents par ordre croissant en fonction du champ spécifié. Si vous avez besoin de trier par ordre décroissant, passez -1 avec le nom du champ -
coll.find().sort("age",-1)
Exemple
L'exemple suivant récupère tous les documents d'une collection classés selon les valeurs d'âge dans l'ordre croissant -
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['b_mydb']
#Creating a collection
coll = db['myColl']
#Inserting document into a collection
data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
{"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
{"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
{"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving first 3 documents using the find() and limit() methods
print("List of documents (sorted in ascending order based on age): ")
for doc1 in coll.find().sort("age"):
print(doc1)
Production
Data inserted ......
List of documents (sorted in ascending order based on age):
{'_id': '1005', 'name': 'Sarmista', 'age': 23, 'city': 'Delhi'}
{'_id': '1004', 'name': 'Romeo', 'age': 25, 'city': 'Pune'}
{'_id': '1006', 'name': 'Rasajna', 'age': 26, 'city': 'Chennai'}
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Vous pouvez supprimer des documents dans une collection à l'aide de remove()méthode de MongoDB. Cette méthode accepte deux paramètres facultatifs -
Critères de suppression spécifiant la condition de suppression des documents.
Un seul, si vous passez true ou 1 comme deuxième paramètre, un seul document sera supprimé.
Syntaxe
Voici la syntaxe de la méthode remove () -
>db.COLLECTION_NAME.remove(DELLETION_CRITTERIA)
Exemple
Supposons que nous ayons créé une collection et y avons inséré 5 documents comme indiqué ci-dessous -
> use testDB
switched to db testDB
> db.createCollection("myColl")
{ "ok" : 1 }
> data = [
... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
... {"_id": "1002", "name": "Rahim", "age": 27, "city": "Bangalore"},
... {"_id": "1003", "name": "Robert", "age": 28, "city": "Mumbai"},
... {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
... {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
... {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
> db.sample.insert(data)
BulkWriteResult({
"writeErrors" : [ ],
"writeConcernErrors" : [ ],
"nInserted" : 6,
"nUpserted" : 0,
"nMatched" : 0,
"nModified" : 0,
"nRemoved" : 0,
"upserted" : [ ]
})
La requête suivante supprime le (s) document (s) de la collection dont le nom est Sarmista.
> db.sample.remove({"name": "Sarmista"})
WriteResult({ "nRemoved" : 1 })
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
{ "_id" : "1004", "name" : "Romeo", "age" : 25, "city" : "Pune" }
{ "_id" : "1006", "name" : "Rasajna", "age" : 26, "city" : "Chennai" }
Si vous invoquez remove() méthode sans passer les critères de suppression, tous les documents de la collection seront supprimés.
> db.sample.remove({})
WriteResult({ "nRemoved" : 5 })
> db.sample.find()
Suppression de documents à l'aide de Python
Pour supprimer des documents d'une collection de MangoDB, vous pouvez supprimer des documents d'une collection à l'aide des méthodes delete_one() et delete_many() méthodes.
Ces méthodes acceptent un objet de requête spécifiant la condition de suppression des documents.
La méthode detele_one () supprime un seul document, en cas de correspondance. Si aucune requête n'est spécifiée, cette méthode supprime le premier document de la collection.
Exemple
L'exemple python suivant supprime le document de la collection dont la valeur id est 1006.
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['lpaksgf']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
{"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
{"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
{"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Deleting one document
coll.delete_one({"_id" : "1006"})
#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
print(doc2)
Production
Data inserted ......
Documents in the collection after update operation:
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
{'_id': '1004', 'name': 'Romeo', 'age': 25, 'city': 'Pune'}
{'_id': '1005', 'name': 'Sarmista', 'age': 23, 'city': 'Delhi'}
De même, le delete_many() La méthode de pymongo supprime tous les documents qui remplissent la condition spécifiée.
Exemple
L'exemple suivant supprime tous les documents de la collection dont la valeur d'âge est supérieure à 26 -
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['sampleDB']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
{"_id": "1004", "name": "Romeo", "age": "25", "city": "Pune"},
{"_id": "1005", "name": "Sarmista", "age": "23", "city": "Delhi"},
{"_id": "1006", "name": "Rasajna", "age": "26", "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Deleting multiple documents
coll.delete_many({"age":{"$gt":"26"}})
#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
print(doc2)
Production
Data inserted ......
Documents in the collection after update operation:
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1004', 'name': 'Romeo', 'age': '25', 'city': 'Pune'}
{'_id': '1005', 'name': 'Sarmista', 'age': '23', 'city': 'Delhi'}
{'_id': '1006', 'name': 'Rasajna', 'age': '26', 'city': 'Chennai'}
Si vous appelez la méthode delete_many () sans passer aucune requête, cette méthode supprime tous les documents de la collection.
coll.delete_many({})
Vous pouvez supprimer des collections en utilisant drop() méthode de MongoDB.
Syntaxe
Voici la syntaxe de la méthode drop () -
db.COLLECTION_NAME.drop()
Exemple
L'exemple suivant supprime la collection avec le nom sample -
> show collections
myColl
sample
> db.sample.drop()
true
> show collections
myColl
Suppression d'une collection à l'aide de Python
Vous pouvez déposer / supprimer une collection du courant en appelant la méthode drop ().
Exemple
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['example2']
#Creating a collection
col1 = db['collection']
col1.insert_one({"name": "Ram", "age": "26", "city": "Hyderabad"})
col2 = db['coll']
col2.insert_one({"name": "Rahim", "age": "27", "city": "Bangalore"})
col3 = db['myColl']
col3.insert_one({"name": "Robert", "age": "28", "city": "Mumbai"})
col4 = db['data']
col4.insert_one({"name": "Romeo", "age": "25", "city": "Pune"})
#List of collections
print("List of collections:")
collections = db.list_collection_names()
for coll in collections:
print(coll)
#Dropping a collection
col1.drop()
col4.drop()
print("List of collections after dropping two of them: ")
#List of collections
collections = db.list_collection_names()
for coll in collections:
print(coll)
Production
List of collections:
coll
data
collection
myColl
List of collections after dropping two of them:
coll
myColl
Vous pouvez mettre à jour le contenu d'un document existant à l'aide du update() méthode ou save() méthode.
La méthode de mise à jour modifie le document existant tandis que la méthode save remplace le document existant par le nouveau.
Syntaxe
Voici la syntaxe des méthodes update () et save () de MangoDB -
>db.COLLECTION_NAME.update(SELECTION_CRITERIA, UPDATED_DATA)
Or,
db.COLLECTION_NAME.save({_id:ObjectId(),NEW_DATA})
Exemple
Supposons que nous ayons créé une collection dans une base de données et inséré 3 enregistrements comme indiqué ci-dessous -
> use testdatabase
switched to db testdatabase
> data = [
... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
... {"_id": "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" },
... {"_id": "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
]
[
{"_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad"},
{"_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore"},
{"_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai"}
]
> db.createCollection("sample")
{ "ok" : 1 }
> db.sample.insert(data)
La méthode suivante met à jour la valeur de la ville du document avec l'ID 1002.
>db.sample.update({"_id":"1002"},{"$set":{"city":"Visakhapatnam"}})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Visakhapatnam" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
De même, vous pouvez remplacer le document par de nouvelles données en l'enregistrant avec le même identifiant en utilisant la méthode save ().
> db.sample.save({ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Vijayawada" })
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.sample.find()
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Vijayawada" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Visakhapatnam" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
Mettre à jour des documents à l'aide de python
Similaire à la méthode find_one () qui récupère un seul document, la méthode update_one () de pymongo met à jour un seul document.
Cette méthode accepte une requête spécifiant le document à mettre à jour et l'opération de mise à jour.
Exemple
L'exemple python suivant met à jour la valeur d'emplacement d'un document dans une collection.
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['myDB']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving all the records using the find() method
print("Documents in the collection: ")
for doc1 in coll.find():
print(doc1)
coll.update_one({"_id":"102"},{"$set":{"city":"Visakhapatnam"}})
#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
print(doc2)
Production
Data inserted ......
Documents in the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Documents in the collection after update operation:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Visakhapatnam'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
De même, le update_many() La méthode de pymongo met à jour tous les documents qui remplissent la condition spécifiée.
Exemple
L'exemple suivant met à jour la valeur d'emplacement dans tous les documents d'une collection (condition vide) -
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['myDB']
#Creating a collection
coll = db['example']
#Inserting document into a collection
data = [
{"_id": "101", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "102", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "103", "name": "Robert", "age": "28", "city": "Mumbai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving all the records using the find() method
print("Documents in the collection: ")
for doc1 in coll.find():
print(doc1)
coll.update_many({},{"$set":{"city":"Visakhapatnam"}})
#Retrieving all the records using the find() method
print("Documents in the collection after update operation: ")
for doc2 in coll.find():
print(doc2)
Production
Data inserted ......
Documents in the collection:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}
Documents in the collection after update operation:
{'_id': '101', 'name': 'Ram', 'age': '26', 'city': 'Visakhapatnam'}
{'_id': '102', 'name': 'Rahim', 'age': '27', 'city': 'Visakhapatnam'}
{'_id': '103', 'name': 'Robert', 'age': '28', 'city': 'Visakhapatnam'}
Lors de la récupération du contenu d'une collection, vous pouvez limiter le nombre de documents dans le résultat à l'aide de la méthode limit (). Cette méthode accepte une valeur numérique représentant le nombre de documents que vous voulez dans le résultat.
Syntaxe
Voici la syntaxe de la méthode limit () -
>db.COLLECTION_NAME.find().limit(NUMBER)
Exemple
Supposons que nous ayons créé une collection et y avons inséré 5 documents comme indiqué ci-dessous -
> use testDB
switched to db testDB
> db.createCollection("sample")
{ "ok" : 1 }
> data = [
... {"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
... {"_id": "1002", "name": "Rahim", "age": 27, "city": "Bangalore"},
... {"_id": "1003", "name": "Robert", "age": 28, "city": "Mumbai"},
... {"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
... {"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
... {"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
> db.sample.insert(data)
BulkWriteResult({
"writeErrors" : [ ],
"writeConcernErrors" : [ ],
"nInserted" : 6,
"nUpserted" : 0,
"nMatched" : 0,
"nModified" : 0,
"nRemoved" : 0,
"upserted" : [ ]
})
La ligne suivante récupère les 3 premiers documents de la collection.
> db.sample.find().limit(3)
{ "_id" : "1001", "name" : "Ram", "age" : "26", "city" : "Hyderabad" }
{ "_id" : "1002", "name" : "Rahim", "age" : 27, "city" : "Bangalore" }
{ "_id" : "1003", "name" : "Robert", "age" : 28, "city" : "Mumbai" }
Limiter les documents à l'aide de Python
Pour limiter les résultats d'une requête à un nombre particulier de documents, pymongo fournit le limit()méthode. À cette méthode, transmettez une valeur numérique représentant le nombre de documents dont vous avez besoin dans le résultat.
Exemple
L'exemple suivant récupère les trois premiers documents d'une collection.
from pymongo import MongoClient
#Creating a pymongo client
client = MongoClient('localhost', 27017)
#Getting the database instance
db = client['l']
#Creating a collection
coll = db['myColl']
#Inserting document into a collection
data = [
{"_id": "1001", "name": "Ram", "age": "26", "city": "Hyderabad"},
{"_id": "1002", "name": "Rahim", "age": "27", "city": "Bangalore"},
{"_id": "1003", "name": "Robert", "age": "28", "city": "Mumbai"},
{"_id": "1004", "name": "Romeo", "age": 25, "city": "Pune"},
{"_id": "1005", "name": "Sarmista", "age": 23, "city": "Delhi"},
{"_id": "1006", "name": "Rasajna", "age": 26, "city": "Chennai"}
]
res = coll.insert_many(data)
print("Data inserted ......")
#Retrieving first 3 documents using the find() and limit() methods
print("First 3 documents in the collection: ")
for doc1 in coll.find().limit(3):
print(doc1)
Production
Data inserted ......
First 3 documents in the collection:
{'_id': '1001', 'name': 'Ram', 'age': '26', 'city': 'Hyderabad'}
{'_id': '1002', 'name': 'Rahim', 'age': '27', 'city': 'Bangalore'}
{'_id': '1003', 'name': 'Robert', 'age': '28', 'city': 'Mumbai'}