Outils pour utilisateurs

Outils du site


hackathlon:pronote:mongodb

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|

$ltplus petit que
$gteplus grand ou égal à
$lteplus petit ou égal à
$orou
$andet
$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 (modification externe)