mongoose 介绍

Mongoose 是在 node.js 异步环境下对 mongodb 进行便捷操作的对象模型工具。Mongoose 是 NodeJS 的驱动,不能作为其他语言的驱动。

Mongoose 有两个特点:通过关系型数据库的思想来设计非关系型数据库;基于 mongodb 驱动,简化操作

官网:https://mongoosejs.com/

mongoose 的安装以及使用

第一步:初始化项目

创建一个项目文件夹,进入文件夹生成package.json文件

npm init --yes

第二步:安装mongoose

npm i mongoose --save

第三步:创建操作mongoose的js模块并且引入和连接数据库

需要先启动mongoDB服务,并且先创建一个数据库eggcms和一个users集合(表)

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms');

// 如果有账户密码需要采用下面的连接方式:
// mongoose.connect('mongodb://eggadmin:123456@127.0.0.1:27017/eggcms');

第四步:定义Schema

数据库中的 Schema,为数据库对象的集合。 schema 是 mongoose 里会用到的一种数据模式, 可以理解为表结构的定义;每个 schema 会映射到 mongodb 中的一个 collection,它不具备 操作数据库的能力

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms');

// 如果有账户密码需要采用下面的连接方式:
// mongoose.connect('mongodb://eggadmin:123456@127.0.0.1:27017/eggcms'); // 定义一个Schema,操作users集合
// Schema里面的对象和数据库表里面的字段需要一一对应
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
})

第五步:创建数据模型

定义好了 Schema,接下就是生成 Model。model 是由 schema 生成的模型,可以对数据库的 操作。

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms');

// 如果有账户密码需要采用下面的连接方式:
// mongoose.connect('mongodb://eggadmin:123456@127.0.0.1:27017/eggcms'); // 定义一个Schema,操作users集合
// Schema里面的对象和数据库表里面的字段需要一一对应
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
}) // 定义数据库模型 操作数据库
// 注意:mongoose.model 里面可以传入两个参数也可以传入三个参数,mongoose.model(参数 1:模型名称(首字母大写),参数 2:Schema,参数 3:数据库集合名 称)
// 如果传入 3 个参数的话:模型默认操作第三个参数定义的集合名称
// 如果传入 2 个参数的话:这个模型会和模型名称相同的复数的数据库建立连接:如通过下面 方法创建模型,那么这个模型将会操作 users 这个集合。
// var User = mongoose.model('User',UserSchema); // 默认会操作 users表(集合)
var User = mongoose.model('User',UserSchema,'users'); //默认会操作第三个参数配置的表 user表(集合)

第六步:操作数据库

增加数据,通过实例化User Molde 创建增加的数据,最后实例.save()

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms');

// 如果有账户密码需要采用下面的连接方式:
// mongoose.connect('mongodb://eggadmin:123456@127.0.0.1:27017/eggcms'); // 定义一个Schema,操作users集合
// Schema里面的对象和数据库表里面的字段需要一一对应
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
}) // 定义数据库模型 操作数据库
// 注意:mongoose.model 里面可以传入两个参数也可以传入三个参数,mongoose.model(参数 1:模型名称(首字母大写),参数 2:Schema,参数 3:数据库集合名 称)
// 如果传入 3 个参数的话:模型默认操作第三个参数定义的集合名称
// 如果传入 2 个参数的话:这个模型会和模型名称相同的复数的数据库建立连接:如通过下面 方法创建模型,那么这个模型将会操作 users 这个集合。
// var User = mongoose.model('User',UserSchema); // 默认会操作 users表(集合)
let User = mongoose.model('User',UserSchema,'users'); //默认会操作第三个参数配置的表 user表(集合) // 增加数据
let u = new User({
name: '李四',
age: 23,
status: 1
})
u.save((err) => {
if (err) {
console.log(err)
return
}
console.log('增加数据成功')
})

查询users表的数据

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms');

// 如果有账户密码需要采用下面的连接方式:
// mongoose.connect('mongodb://eggadmin:123456@127.0.0.1:27017/eggcms'); // 定义一个Schema,操作users集合
// Schema里面的对象和数据库表里面的字段需要一一对应
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
}) // 定义数据库模型 操作数据库
// 注意:mongoose.model 里面可以传入两个参数也可以传入三个参数,mongoose.model(参数 1:模型名称(首字母大写),参数 2:Schema,参数 3:数据库集合名 称)
// 如果传入 3 个参数的话:模型默认操作第三个参数定义的集合名称
// 如果传入 2 个参数的话:这个模型会和模型名称相同的复数的数据库建立连接:如通过下面 方法创建模型,那么这个模型将会操作 users 这个集合。
// var User = mongoose.model('User',UserSchema); // 默认会操作 users表(集合)
let User = mongoose.model('User',UserSchema,'users'); //默认会操作第三个参数配置的表 user表(集合) // 增加数据
let u = new User({
name: '李四',
age: 23,
status: 1
})
u.save((err) => {
if (err) {
console.log(err)
return
}
console.log('增加数据成功')
}) // 查询users表的数据
User.find({}, (err, doc) => {
if (err) {
console.log(err)
return
}
console.log(doc)
})

更新数据

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms');

// 如果有账户密码需要采用下面的连接方式:
// mongoose.connect('mongodb://eggadmin:123456@127.0.0.1:27017/eggcms'); // 定义一个Schema,操作users集合
// Schema里面的对象和数据库表里面的字段需要一一对应
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
}) // 定义数据库模型 操作数据库
// 注意:mongoose.model 里面可以传入两个参数也可以传入三个参数,mongoose.model(参数 1:模型名称(首字母大写),参数 2:Schema,参数 3:数据库集合名 称)
// 如果传入 3 个参数的话:模型默认操作第三个参数定义的集合名称
// 如果传入 2 个参数的话:这个模型会和模型名称相同的复数的数据库建立连接:如通过下面 方法创建模型,那么这个模型将会操作 users 这个集合。
// var User = mongoose.model('User',UserSchema); // 默认会操作 users表(集合)
let User = mongoose.model('User',UserSchema,'users'); //默认会操作第三个参数配置的表 user表(集合) // 更新数据
User.updateOne({
'_id': '5cdc42953beb59420c5893c6'
}, {
'name': '王五',
'age': 11
}, (err, doc) => {
if (err) {
console.log(err)
return
}
console.log(doc)
})

删除数据

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms');

// 如果有账户密码需要采用下面的连接方式:
// mongoose.connect('mongodb://eggadmin:123456@127.0.0.1:27017/eggcms'); // 定义一个Schema,操作users集合
// Schema里面的对象和数据库表里面的字段需要一一对应
let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: Number
}) // 定义数据库模型 操作数据库
// 注意:mongoose.model 里面可以传入两个参数也可以传入三个参数,mongoose.model(参数 1:模型名称(首字母大写),参数 2:Schema,参数 3:数据库集合名 称)
// 如果传入 3 个参数的话:模型默认操作第三个参数定义的集合名称
// 如果传入 2 个参数的话:这个模型会和模型名称相同的复数的数据库建立连接:如通过下面 方法创建模型,那么这个模型将会操作 users 这个集合。
// var User = mongoose.model('User',UserSchema); // 默认会操作 users表(集合)
let User = mongoose.model('User',UserSchema,'users'); //默认会操作第三个参数配置的表 user表(集合) // 删除数据
User.deleteOne({
'_id': '5cdc42953beb59420c5893c6'
}, (err, result) => {
if(err){
return console.log(err);
}
console.log(result)
})

mongoose 默认参数

增加数据的时候,如果不传入数据会使用默认配置的数据(在定义Schema的时候,去设置),下面增加数据的时候只写了两个参数

const mongoose = require('mongoose');

// useNewUrlParser是4.0版本之后,不写这个参数会有警告,这个属性会在url里识别验证用户所需的db,4.0前是不需要指定的
// 第三个参数添加一个回调函数,获取数据库连接是否成功
mongoose.connect('mongodb://127.0.0.1:27017/eggcms', { useNewUrlParser: true }, (err) => {
if(err){
return console.log(err);
}
console.log('数据库连接成功')
}); let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: {
type: Number,
default: 1
}
}) // 定义model操作数据库
let User = mongoose.model('User',UserSchema,'users'); // 增加数据
let u = new User({
name: '赵六',
age: 23
})
u.save((err) => {
if (err) {
console.log(err)
return
}
console.log('增加数据成功')
}) // 查询users表的数据
User.find({}, (err, doc) => {
if (err) {
console.log(err)
return
}
console.log(doc)
})

mongoose 模块化

在项目中操作数据库的文件夹中,新建一个文件夹model,并且创建一个db.js文件用于连接数据库,并且暴露出来即可

const mongoose = require('mongoose');

mongoose.connect('mongodb://127.0.0.1:27017/eggcms', { useNewUrlParser: true }, (err) => {
if(err){
return console.log(err);
}
console.log('数据库连接成功')
}); module.exports = mongoose

接下来定义子模块,比如操作users集合,那么就在model中创建一个users.js,并且将操作模型暴露出去

let mongoose = require('./db')

let UserSchema = mongoose.Schema({
name: String,
age: Number,
status: {
type: Number,
default: 1
}
}) // 定义model操作数据库
let UserModel = mongoose.model('User',UserSchema,'users'); module.exports = UserModel

然后再app.js中如果需要操作那个集合就引入哪个集合的操作模型,然后进行数据库操作

let UserModel = require('./model/users')

// 增加数据
let u = new UserModel({
name: '黄中国',
age: 23
})
u.save((err) => {
if (err) {
console.log(err)
return
}
console.log('增加数据成功') // 查询users表的数据
UserModel.find({}, (err, doc) => {
if (err) {
console.log(err)
return
}
console.log(doc)
})
})

性能测试

console.time('user');
let UserModel = require('./model/users')
console.timeEnd('user'); // 假设还有一个模块,引入user的时候,已经连接了数据库,这里第二次引入别的模块不会在连接数据库,直接可以使用
console.time('news');
let UserModel = require('./model/news')
console.timeEnd('');

Mongoose 入门以及实现数据的增、删、改、查的更多相关文章

  1. 好用的SQL TVP~~独家赠送[增-删-改-查]的例子

    以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化.  本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...

  2. iOS FMDB的使用(增,删,改,查,sqlite存取图片)

    iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...

  3. iOS sqlite3 的基本使用(增 删 改 查)

    iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...

  4. django ajax增 删 改 查

    具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...

  5. ADO.NET 增 删 改 查

    ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...

  6. MVC EF 增 删 改 查

    using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...

  7. python基础中的四大天王-增-删-改-查

    列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...

  8. 简单的php数据库操作类代码(增,删,改,查)

    这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...

  9. MongoDB增 删 改 查

    增 增加单篇文档 > db.stu.insert({sn:'001', name:'lisi'}) WriteResult({ "nInserted" : 1 }) > ...

随机推荐

  1. pytest之mark功能

    pytest系列(一)中给大家介绍了pytest的特性,以及它的编写用例的简单至极. 那么在实际工作当中呢,我们要写的自动化用例会比较多,不会都放在一个py文件里. 如下图所示,我们编写的用例存放在不 ...

  2. 二.HTML

    1.HTML 1. <head></head>标签 <!DOCTYPE html> <!--统一规范--> <!----> <html ...

  3. iOS架构:MVVM设计模式+RAC响应式编程

    https://cloud.tencent.com/developer/article/1117009 一:为什么要用MVVM? 为什么要用MVVM?只是因为它不会让我时常懵逼. 每次做完项目过后,都 ...

  4. 学习笔记之Python 3

    学习笔记之Python 3 教程 https://www.cnblogs.com/pegasus923/p/7624416.html 学习笔记之X分钟速成Python3 https://www.cnb ...

  5. React学习笔记②

    import React,{Component} from 'react'; import Child from './Child.js' class App extends Component{ c ...

  6. gulp与webpack的区别?是一种工具吗?

    问:gulp和webpack什么关系,是一种东西吗?可以只用gulp,不用webpack吗 或者反过来?有什么区别? 答:gulp是工具链.自动化构建工具,可以配合各种插件,我们不用再做机械重复的工作 ...

  7. ES6的新特性

    ECMAScript 6(简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,又称ECMAScript 2015.ES6就是ES2015. 虽然目前并不是所有 ...

  8. UIDatePicker基本使用

    UIDatePicker提供了一个快速选择日期和时间的控件,他是UIControl的子类,专门用于日期时间的选择.其样式可以通过UIDatePicker的属性进行灵活设置,同时也可以获取到当前UIDa ...

  9. NumPy 之 存储文件和线性代数

    import numpy as np File Input and Output NumPy is able to save and load data to and from disk either ...

  10. SQL SERVER-查看内存使用情况

    --使用内存的各对象 SELECT type, sum(virtual_memory_reserved_kb) as VM_Reserved, sum(virtual_memory_committed ...