MEAN.JS - Datenmodell erstellen
In diesem Kapitel werden wir zeigen, wie das Datenmodell in unserer Node-Express-Anwendung verwendet wird.
MongoDB ist eine Open-Source-NoSQL-Datenbank, die die Daten im JSON-Format speichert. Es verwendet das dokumentorientierte Datenmodell , um die Daten zu speichern, anstatt Tabellen und Zeilen zu verwenden, wie wir sie in den relationalen Datenbanken verwenden. In diesem Kapitel verwenden wir Mongodb, um ein Datenmodell zu erstellen.
Das Datenmodell gibt an, welche Daten in einem Dokument vorhanden sind und welche Daten in einem Dokument vorhanden sein sollen. Informationen zur Installation der MongoDB finden Sie in der offiziellen MongoDB-Installation .
Wir werden unseren vorherigen Kapitelcode verwenden. Sie können den Quellcode unter diesem Link herunterladen . Laden Sie die Zip-Datei herunter. Extrahieren Sie es in Ihrem System. Öffnen Sie das Terminal und führen Sie den folgenden Befehl aus, um die Abhängigkeiten des npm-Moduls zu installieren.
$ cd mean-demo
$ npm install
Hinzufügen von Mungo zur Anwendung
Mongoose ist eine Datenmodellierungsbibliothek, die die Umgebung und Struktur der Daten angibt, indem MongoDB leistungsfähig gemacht wird. Sie können Mongoose als npm-Modul über die Befehlszeile installieren. Gehen Sie zu Ihrem Stammordner und führen Sie den folgenden Befehl aus:
$ npm install --save mongoose
Mit dem obigen Befehl wird das neue Paket heruntergeladen und im Ordner node_modules installiert . Das Flag --save fügt dieses Paket zur Datei package.json hinzu .
{
"name": "mean_tutorial",
"version": "1.0.0",
"description": "this is basic tutorial example for MEAN stack",
"main": "server.js",
"scripts": {
"test": "test"
},
"keywords": [
"MEAN",
"Mongo",
"Express",
"Angular",
"Nodejs"
],
"author": "Manisha",
"license": "ISC",
"dependencies": {
"express": "^4.17.1",
"mongoose": "^5.5.13"
}
}
Verbindungsdatei einrichten
Um mit dem Datenmodell zu arbeiten, verwenden wir den Ordner app / models . Lassen Sie uns das Modell student.js wie folgt erstellen -
var mongoose = require('mongoose');
// define our students model
// module.exports allows us to pass this to other files when it is called
module.exports = mongoose.model('Student', {
name : {type : String, default: ''}
});
Sie können die Verbindungsdatei einrichten, indem Sie die Datei erstellen und in der Anwendung verwenden. Erstellen Sie eine Datei mit dem Namen db.js in config / db.js . Der Dateiinhalt ist wie folgt -
module.exports = {
url : 'mongodb://localhost:27017/test'
}
Hier ist test der Datenbankname.
Hier wird davon ausgegangen, dass Sie MongoDB lokal installiert haben. Nach der Installation starten Sie Mongo und erstellen Sie eine Datenbank nach Namenstest. Diese Datenbank wird eine Sammlung von Studenten haben. Fügen Sie einige Daten in diese Spalte ein. In unserem Fall haben wir einen Datensatz mit db.students.insertOne eingefügt ({Name: 'Manisha', Ort: 'Pune', Land: 'Indien'});
Bringen Sie die Datei db.js in die Anwendung, dh in server.js . Der Inhalt der Datei ist wie folgt:
// modules =================================================
const express = require('express');
const app = express();
var mongoose = require('mongoose');
// set our port
const port = 3000;
// configuration ===========================================
// config files
var db = require('./config/db');
console.log("connecting--",db);
mongoose.connect(db.url); //Mongoose connection created
// frontend routes =========================================================
app.get('/', (req, res) ⇒ res.send('Welcome to Tutorialspoint!'));
//defining route
app.get('/tproute', function (req, res) {
res.send('This is routing for the application developed using Node and Express...');
});
// sample api route
// grab the student model we just created
var Student = require('./app/models/student');
app.get('/api/students', function(req, res) {
// use mongoose to get all students in the database
Student.find(function(err, students) {
// if there is an error retrieving, send the error.
// nothing after res.send(err) will execute
if (err)
res.send(err);
res.json(students); // return all students in JSON format
});
});
// startup our app at http://localhost:3000
app.listen(port, () ⇒ console.log(`Example app listening on port ${port}!`));
Führen Sie als Nächstes die Anwendung mit dem folgenden Befehl aus:
$ npm start
Sie erhalten eine Bestätigung wie im Bild unten gezeigt -
Gehen Sie nun zum Browser und geben Sie ein http://localhost:3000/api/students. Sie erhalten die Seite wie im Bild unten gezeigt -