I was nervous about writing for the nuggets for the first time and decided… Say a little introduction to ease things up!

I believe that there are many comrades who want to enter the full stack line, not only because of interest, but also because of the need to learn more.
Therefore, after all kinds of tutorial videos and learning materials on Baidu, we will definitely find such a technology, which is the core of this article:

What is Mongodb? What convenience can it bring us?

1.1 What is Mongodb?

MongoDB is an open source database system based on distributed file storage written in C++ language. Adding more nodes can ensure server performance under high load conditions.

1.2 What convenience can it bring to us?

There are many benefits to MongoDB. Here are a few:

  1. MongoDB is a document storage oriented database, operation is relatively simple and easy.
  2. Mongo supports rich query expressions. Query instructions use JSON-style tags to easily query objects and arrays embedded in documents.
  3. You can index any attribute in the MongoDB record (e.g. FirstName=”Sameer”,Address=”8 Gandhi Road”) for faster sorting.
  4. You can create data images locally or over the network, which makes MongoDB more scalable.

👌 do not list the shortcomings, not no, just feel that… Blow for a while the loss of not too humane (ha ha ha) online about this aspect of a lot, in fact, to sum up the words that is too long, so here is not one example.


Second, the first step is to set up Mongodb and make full preparations for subsequent operations.

The following file paths are on my Mac as an example, you can configure yourself.

The Homebrew setup is used here

2.1 Open the TERMINAL command line and enter the following code:

brew install mongodb
Copy the code

After the installation is complete, let’s check the current terminal to see if we have successfully installed:

mongod -h
Copy the code

Once the installation is complete, specify a data path and a log path, because you always want to put the data and logs in one place, right?

2.2 Specifying a data path and a log path.

Create a new Mongodb file on your desktop, and then go to the CD and create a folder named data in the Mongodb file. This is where the specified data and log paths will be stored. Enter the following code:

mongod -dbpath="./data"
Copy the code

When we get a display like the one below, we are happy to tell you that our foreplay is complete and we can start GTR 👌 :

This window cannot be closed, because the current terminal command line is equivalent to mongodb service, close it, and stop mongodb service no difference.


  1. The first step was to download mongodb via BREW, and unlike other installations, I chose to install it from the command line instead of downloading the official decompression package.

  2. Once you’ve installed it, of course, since it’s a database there must be data and logs, and we need to get them to a place where we can manage them and do things later, and the code that helps us specify where to save them is mongod-dbPath =” your own path “.

Step 2: Visualization tools that let you see the data? No, just a web page.

We have built the database, how can we see the data in our database?

Remember the Mongodb file you created in step 1? Add a terminal CD to Mongodb and enter the cryptic code:

mongo

After executing the code:

As you probably know, mongodb can query data by command.


  1. Show DBS (query all database lists)
  2. Db (check which database is currently connected)
  3. Use database name (switch under a database)
  4. Show Collections (see what tables are in the current database)
  5. Db.help () (current database support method)

Of course, the Mongodb command line does have queries, so why not list them? Because we have a better tool: adminMongo

AdminMongo is a Mongodb visualization tool, lightweight, portable, can meet the basic tools of daily development

npm install admin-mongo
npm i 
npm start
Copy the code

👌 download three even, we all understand, GTR open can be fast 👌

Anyway, after the download is complete and the project is launched, we can see the screen look something like this:

Here we can create libraries, delete libraries, create tables and so on.

3.1 Creating user Data

Taking my own nextHuafo database as an example, click nextHuafo on the right to go to the main page of the current database:

Create a Users table here:

Insert user data into the current Users table:

👌 is done. Our first data has been inserted successfully.

👌 if you are already very happy here, even very excited, we might as well put the speed up a grade, next, the front and back end began linkage.

Step 4. Step 3: Everything is ready, but it’s time to start linkage.

4.1 Build the project and download Express or Mongoose.

npm install express

npm install mongoose

Use express to manage the route of the interface. Express +Mongodb..

Mongoose is an object model tool for convenient operation of mongodb in node.js asynchronous environment

After downloading, take a look at my project configuration. Here, I directly build the project by VueCli3.0 for convenience. The project path is as follows:

👌 here we create a new server file to store some operations on the database, so before the next step, I hope to give you a general idea.

We need to do five steps:

  1. Connect to the database.
  2. Create the data module Model and write the required business function code.
  3. Get the request parameters and substitute them into the written function for the conditional return.
  4. Set up express routes that route the current method into an interface we can request.
  5. Postman makes a query.

4.2 Connecting a Database

Create a new connection. js file under the server folder for connecting to the database. In the current JS, we need to use mongoose downloaded before to connect and use Mongoose.

var mongoose = require('mongoose') /**** declare a local link to your Mongodb database *****/ var mongooseUrl ='mongo: / / 127.0.0.1:27017 / nextHuafo'/**** link *****/ mongooseUrl (mongooseUrl, {useNewUrlParser:true}, (err) => {
  if(err){
    console.log('Connection Error:' + err)
  }else{
    console.log('Connection success! ')}})Copy the code

Use mongoose.connection.on(‘connected’) to monitor whether your database is successfully connected.

mongoose.connection.on('connected',()=>{
	console.log('Database connection successful')})Copy the code

Or you can listen for connection failures

mongoose.connection.on('err',()=>{
	console.log('Database connection failed')})Copy the code

And then we export our connected Mongoose.

module.exports = mongoose
Copy the code

The last Connection to the database looks like this:

var mongoose = require('mongoose')

var mongooseUrl = 'mongo: / / 127.0.0.1:27017 / nextHuafo'

mongoose.connect(mongooseUrl, {useNewUrlParser: true}, (err) => {
  if(err){
    console.log('Connection Error:' + err)
  }else{
    console.log('Connection success! ')}}) / * * * * * * link success * * * * * * * / mongoose. Check the connection.'connected',()=>{
	console.log('Database connection successful')}) /****** link failure *******/ mongoose.connection.on('err',()=>{
	console.log('Database connection failed')
})

module.exports = mongoose
Copy the code


4.3 Create data module Model and write the required business function code.

In the server file, we create a Schema file. This file is used to store the different business function codes and corresponding module data models that we write for different modules. Let’s take a look at the current directory:

Create the user file named user and create user.js in its directory:

Okay, so that’s what we call model file Schema, so let’s talk a little bit about Schema.

Schema is a kind of data schema used in Mongoose. It can be understood as the definition of table structure. Each schema maps to a collection in mongodb, which does not have the ability to manipulate databases

In Mongoose, everything started with schema. Each schema corresponds to a mongoDB collection and documents models are defined within that collection.

👌 to sum up, here may be summed up in one sentence:

Schema does not have the ability to manipulate databases. It is a data model that defines the structure of the current collection table.

Introduce the connection database file we just defined in user.js.

const mongoose = require('./server/Connection.js') // Is not a real path, modify according to your own conditionsCopy the code

Then define a Schema model.

const User = mongoose.model('user',{
	username:String,
	password:String,
	isLogin:Boolean
})
Copy the code

Model () allows us to convert our defined schemas into models that we can use

The above method is equivalent to:

Username: String, password: String, isLogin: String,}; username: String, password: String, isLogin: String,} var User = mongoose.model('user', userSchema);
Copy the code

Attention! Mongoose will automatically add complex numbers here, so model(‘user’, {}) is equal to model(‘ users’, {}).

Ok 👌, about users, we have defined, now to do, is to write we need to users method, we will first write a simple query!

Continue to write user.js in this file.

Const findUser = (userInfo, Callback) => {user.findone (userInfo). Then ((res) => {callback(res)})} // Module.exports = {findUser}Copy the code

This is followed by a very quick overview of the 3.4.5 process, and at the end of the day, GTR is ready to run! .

4.4 Obtain request parameters and substitute them into written functions for conditional return.

So that’s the query method, so instead of going into that, let’s create a file called userapi.js and introduce the user.js

const userModel = require('./user')
Copy the code

Moving on, we write a prompt for a front-end return based on the conditions returned by the database when the request is received.

const login  = (req, res) => {
  let {username, password,status} = req.body
  userModel.findUser({username}, (user) => {
    if(! user) { res.json({ code: 201, msg:'Username does not exist'})}else {
      if (user.password == password) {
        res.cookie('user', username)
        res.json({
          code: 200,
          msg: 'Login successful! '})}else {
        res.json({
          code: 202,
          msg: 'Password error'Module. Exports = {login,}Copy the code

4.5 Configuring express Routes To change the current method into an interface that can be requested by us.

One level above user.js, we create a router.js file to hold Express routes, and when we request these routes, we are requesting our written methods.

var express = require('express'Var router = express.router () var userController = require()'./user/userApi'// Add userapi.js router.post('/login', userController.login) // Exports module. Exports = routerCopy the code

At this time our work will do seven seven eight eight, but we must run! Create the app.js middleware in the outermost layer, and create port 3030 in the middleware. Use the app.use() method to associate the route you just exported.

var express = require('express');

var cors = require('cors');

var app = express()

var mongoose = require('mongoose');

const bodyPaser = require('body-parser'); app.use(cors()); // app.use(bodypaser. urlencoded({extended: coded); // App.use (bodypaser. urlencoded({extended: coded); // App.use (bodypaser. urlencoded({extended: coded); // App.use (bodypaser. urlencoded({extended: coded);false}))
app.use(bodyPaser.urlencoded({extended:true}));

app.get('/'.function(req,res){
  res.send("Startup successful")

})


var usersRouter = require('./server/SchemaApi/router')

app.use('/api/user',usersRouter)

app.listen(3030,() => {
  console.log("Node 3030 port succeeded")})Copy the code
Nodeapp.js // Start upCopy the code

4.6 Summary 3. 4. 5 Steps are done specifically.

Okay, so now that we’ve looked at the code, it’s time to talk about why they write it this way.

Why was the previous query method called query method? It’s findOne().

const findUser = (userInfo, callback) => {
	User.findOne(userInfo).then((res) => {
		callback(res)
	})
}
Copy the code

The findOne () method, which returns the first record that matches the condition

This is exactly what mongodb provides, where findOne () takes a userInfo argument.

👌OK, let’s continue, userapi.js is written to receive the request method why?

Remember our router.js? Express routing to request the current file, if you still don’t have a clue let’s look at this code again.

var userController = require('./user/userApi')

router.post('/login', userController.login)
Copy the code

Userapi.js:

const login  = (req, res) => {
  let {username, password,status} = req.body
  userModel.findUser({username}, (user) => {
    if(! user) { res.json({ code: 201, msg:'Username does not exist'})}else {
      if (user.password == password) {
        res.cookie('user', username)
        res.json({
          code: 200,
          msg: 'Login successful! '})}else {
        res.json({
          code: 202,
          msg: 'Password error'
        })
      }
    }
  })
}

module.exports = {
   login
}
Copy the code

It is obvious that router.post () in router.js requests the exported login method, which takes two arguments, req and res. Our request parameter is req.body.

Here we have the express route written, then we just need to use app.use in the middleware association.

4.7 Postman Performing A Query.

Now that you’ve run and written, it’s time to check if your code is correct. Open Postman to check your interface, and watch yourself start the terminal in the middle.

????? What’s going on? What a mistake? I’ve been writing for half a day! I can’t believe you made a mistake! Spicy chicken article I’m gonna report you! Fake!

When we come across this problem, see what mistakes he reports.

Cannot destructure property username of ‘undefined’ or ‘null’.

Please pay attention here:

In Express4.0, req.body is stripped out and needs to be manually introduced in app.js to parse req.body

const bodyPaser = require('body-parser');

app.use(bodyPaser.urlencoded({extended:true}));
Copy the code

Add these two lines of code to your app.js. If you don’t have body-Parser, you can download it by NPM (BTW, I used to write body-praser as body-parser and then spent half an hour wondering why I didn’t have it…).

👌OK, now let’s restart the node app.js terminal, and then postman request to see if it works properly.

And you’re done! 👌, so we have covered the most basic mongodb operations. In fact, it is so simple, is it not so difficult as imagined? Finally, take a look at my catalog:

Finally, this project is also on Github, I added some new things, you can look at this, ask for a star! Gnome male -“

Github.com/FuhanLXK/Sh…

So, Mongodb to this is all over, write two days, because their first article so many are not familiar with, I as a thorough front-end code son, write will write, say the words may be completely not professional.

After looking at the big guy’s article and his own article, the gap immediately came out, but I still felt excited, because for myself, I finally took this step.

If there are mistakes or careless places in the article, people actively put forward their opinions to me, I also need to grow, and I will actively modify.

Soon to turn 20, I hope I can keep this passion forever.

May you always have light, not fear, and a bright future in solitude.