No renderer 'odt' found for mode 'odt'
hackathlon:pronote:mongodb
Table des matières
Pronote : installer et découvrir MongoDB
Installation
Lien : https://docs.mongodb.com/manual/tutorial/install-mongodb-on-debian/
- se connecter en SSH au serveur Debian sur lequel est installer NodeJS
- importer la clé publique
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 0C49F3730359A14518585931BC711F9BA15703C6
- créer le fichier /etc/apt/sources.list.d/mongodb-org-3.4.list
echo "deb http://repo.mongodb.org/apt/debian jessie/mongodb-org/3.4 main" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.4.list
- Mettre à jour la liste des paquets
sudo apt-get update
- installer MongoDB
sudo apt-get install -y mongodb-org
- lancer MOngoDB qui sera en écoute sur le port 27017
sudo service mongodb start
Première prise en main
Lien : https://openclassrooms.com/courses/guide-de-demarrage-pour-utiliser-mongodb
- Le format JSON (JavaScript Object Notation) est utilisé pour l'insertion et la restitution des documents.
- MongoDB stocke les documents dans un format binaire appelé BSON.
- * Lancer l'interpréteur de commandes :
mongo >
Créer une base de données
- il suffit de se positionner sur une base qui est alors créée si elle n'existe pas :
> use moyennes > switched to db moyennes
- Une base de données contient des collections dans lesquelles on ajoute des documents de même nature. Dans un SGBDR il s'agirait d'une table.
création d'une collection
>db.annee.insert({"annee":2016,"classe":"B1 SIO","periode":"Semestre 2","nbEleves":"35","moyenneClasse":"11,19"})
- lire le contenu d'une table ; MongoDB ajoute une propriété “_id” qui est un identifiant unique ObjectId pour le document si celui-ci n'est pas spécifié à l'insertion.
> db.annee.find() { "_id" : ObjectId("5913641110464938586b0faf"), "annee" : 2016, "classe" : "B1 SIO", "periode" : "Semestre 2", "nbEleves" : "35", "moyenneClasse" : "11,19" }
- MongoDb est schemaless, ce qui signifie que les documents n'ont pas tous à respecter le même format.
Faire une recherche
- ajout de plusieurs enregistrements de classe puis recherche sur une classe précise
>db.annee.insert({"annee":2016,"classe":"B1 SIO","periode":"Semestre 1","nbEleves":"35","moyenneClasse":"11,76"}) >db.annee.insert({"annee":2016,"classe":"B1 SIO","periode":"Année (Deux semestres)","nbEleves":"35","moyenneClasse":"11,48"}) > db.annee.find({"moyenneClasse":"11,76"})
- compter le nombre de résultats
> db.annee.find({"classe":"B1 SIO"}).count()
- Les opérandes
|$gt|plus grand que|
$lt | plus petit que |
$gte | plus grand ou égal à |
$lte | plus petit ou égal à |
$or | ou |
$and | et |
$in, $all, $exist, $type et $regex … |
db.annee.find({moyenneClasse: {$gte:"11", $lt:"11,50"}})
Choisir les informations à afficher
db.annee.find({moyenneClasse: {$gte:"11", $lt:"11,50"}}, {"_id":0, "periode":1})
- Mettre la valeur 0 à _id pour que ce champ ne soit pas affiché
Trier ave la méthode sort()
db.annee.find({"moyenneClasse": {$gte:"11", $lt:"11,50"}}, {"_id":0, "periode":1}).sort({"moyenneClasse":1})
- mettre -1 pour un tri décroissant
Exemple
- créer un document année et ajouter successivement les classes
db.annee.insert({annee: 2016}) // ajouter une propriété db.annee.update({annee:2016}, {$set : {classe:"B1 SIO"}}) // supprimer une propriété db.annee.update({annee:2016}, {$unset : {classe:1}}) // ajouter un tableau classe db.annee.update({annee:2016}, {$set : {classe:[]}}) // ajouter un element au tableau db.annee.update({annee:2016}, {$push : {classe: "B1 SIO"}}) db.annee.update({annee:2016}, {$push : {classe: "B2 SIO"}}) db.annee.update({annee:2016}, {$push : {classe: {libelle:"B2 SIO"}}}) //supprimer un document db.annee.remove({})
- gérer les tableau de moyennes du lycée Suzanne Valadon
db.classes.insert({'etablissement':'0870019y', 'annee':'2017'}) db.classes.update({'etablissement':'0870019y', 'annee':'2017'}, {$push : {classe: {libelle:"B1_SIO"}}}) db.classes.update({'etablissement':'0870019y', 'annee':'2017'}, {$push : {classe: {libelle:"B2_SIO"}}})
MongoDB avec Node.JS
Retour projet 2017
hackathlon/pronote/mongodb.txt · Dernière modification : 2017/06/07 10:09 de 127.0.0.1