Mongoose 入门以及实现数据的增、删、改、查
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 入门以及实现数据的增、删、改、查的更多相关文章
- 好用的SQL TVP~~独家赠送[增-删-改-查]的例子
以前总是追求新东西,发现基础才是最重要的,今年主要的目标是精通SQL查询和SQL性能优化. 本系列主要是针对T-SQL的总结. [T-SQL基础]01.单表查询-几道sql查询题 [T-SQL基础] ...
- iOS FMDB的使用(增,删,改,查,sqlite存取图片)
iOS FMDB的使用(增,删,改,查,sqlite存取图片) 在上一篇博客我对sqlite的基本使用进行了详细介绍... 但是在实际开发中原生使用的频率是很少的... 这篇博客我将会较全面的介绍FM ...
- iOS sqlite3 的基本使用(增 删 改 查)
iOS sqlite3 的基本使用(增 删 改 查) 这篇博客不会讲述太多sql语言,目的重在实现sqlite3的一些基本操作. 例:增 删 改 查 如果想了解更多的sql语言可以利用强大的互联网. ...
- django ajax增 删 改 查
具于django ajax实现增 删 改 查功能 代码示例: 代码: urls.py from django.conf.urls import url from django.contrib impo ...
- ADO.NET 增 删 改 查
ADO.NET:(数据访问技术)就是将C#和MSSQL连接起来的一个纽带 可以通过ADO.NET将内存中的临时数据写入到数据库中 也可以将数据库中的数据提取到内存中供程序调用 ADO.NET所有数据访 ...
- MVC EF 增 删 改 查
using System;using System.Collections.Generic;using System.Linq;using System.Web;//using System.Data ...
- python基础中的四大天王-增-删-改-查
列表-list-[] 输入内存储存容器 发生改变通常直接变化,让我们看看下面列子 增---默认在最后添加 #append()--括号中可以是数字,可以是字符串,可以是元祖,可以是集合,可以是字典 #l ...
- 简单的php数据库操作类代码(增,删,改,查)
这几天准备重新学习,梳理一下知识体系,同时按照功能模块划分做一些东西.所以.mysql的操作成为第一个要点.我写了一个简单的mysql操作类,实现数据的简单的增删改查功能. 数据库操纵基本流程为: 1 ...
- MongoDB增 删 改 查
增 增加单篇文档 > db.stu.insert({sn:'001', name:'lisi'}) WriteResult({ "nInserted" : 1 }) > ...
随机推荐
- pytest之mark功能
pytest系列(一)中给大家介绍了pytest的特性,以及它的编写用例的简单至极. 那么在实际工作当中呢,我们要写的自动化用例会比较多,不会都放在一个py文件里. 如下图所示,我们编写的用例存放在不 ...
- 二.HTML
1.HTML 1. <head></head>标签 <!DOCTYPE html> <!--统一规范--> <!----> <html ...
- iOS架构:MVVM设计模式+RAC响应式编程
https://cloud.tencent.com/developer/article/1117009 一:为什么要用MVVM? 为什么要用MVVM?只是因为它不会让我时常懵逼. 每次做完项目过后,都 ...
- 学习笔记之Python 3
学习笔记之Python 3 教程 https://www.cnblogs.com/pegasus923/p/7624416.html 学习笔记之X分钟速成Python3 https://www.cnb ...
- React学习笔记②
import React,{Component} from 'react'; import Child from './Child.js' class App extends Component{ c ...
- gulp与webpack的区别?是一种工具吗?
问:gulp和webpack什么关系,是一种东西吗?可以只用gulp,不用webpack吗 或者反过来?有什么区别? 答:gulp是工具链.自动化构建工具,可以配合各种插件,我们不用再做机械重复的工作 ...
- ES6的新特性
ECMAScript 6(简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,又称ECMAScript 2015.ES6就是ES2015. 虽然目前并不是所有 ...
- UIDatePicker基本使用
UIDatePicker提供了一个快速选择日期和时间的控件,他是UIControl的子类,专门用于日期时间的选择.其样式可以通过UIDatePicker的属性进行灵活设置,同时也可以获取到当前UIDa ...
- NumPy 之 存储文件和线性代数
import numpy as np File Input and Output NumPy is able to save and load data to and from disk either ...
- SQL SERVER-查看内存使用情况
--使用内存的各对象 SELECT type, sum(virtual_memory_reserved_kb) as VM_Reserved, sum(virtual_memory_committed ...