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 }) > ...
随机推荐
- C++之拷贝控制 (Copy Control)
只有2种成员 值成员: 指针成员: 依实现可分为raw pointer / shared_ptr; 现在,仅考虑第③种:资源对象共享 角度来考虑拷贝控制 类的两种语义:值语义.似指针 编译器提供的de ...
- tf.random_shuffle()函数解析
tf.random_shuffle(value, seed=None, name=None) 函数就是随机地将张量沿第一维度打乱 value:将被打乱的张量. seed:一个 Python 整数.用于 ...
- ssh工具推荐
FinalShell 看图就知道功能多强大了, 官网地址 http://www.hostbuf.com
- JCEF-鼠标右键菜单
为鼠标添加自定义菜单,比较简单,实现一个Handler就行 Hanler实现类 public class MenuHandler extends CefContextMenuHandlerAdapte ...
- Unity手游汉化笔记③:UABE替换BMFont
总的笔记:https://www.cnblogs.com/guobaoxu/p/12055930.html 目录 一.Demo 二.分析思路 三.替换 四.总结 五.补充 工具: Unity版本:20 ...
- MySQL 如何优化大分页查询?
一 背景 大部分开发和DBA同行都对分页查询非常非常了解,看帖子翻页需要分页查询,搜索商品也需要分页查询.那么问题来了,遇到上千万或者上亿的数据量怎么快速的拉取全量,比如大商家拉取每月千万级别的订单数 ...
- OCR5:预处理
Tesseract4.X已经有了初步成效(见下面的对比), 但目前结果对于训练之外的数据, 仍会有很大的偏差.想要更好的 OCR 结果, README 中重点强调的一点是: 在交给 Tesseract ...
- Oracle11g 干净卸载
原文链接:https://www.cnblogs.com/su-root/p/9689787.html 作 者:小柏 出 处:https://www.cnblogs.com/su-root Ora ...
- 【解决】挂载NFS服务时,不同共享客户端间的数据不同步
问题现象 当您用台 ECS 挂载同一个 NFS 文件系统,在 ECS-A 上 append 写文件,在 ECS-B 用 tail -f 观察文件内容的变化.在 ECS-A 写完之后,在 ECS-B 看 ...
- virt-install创建虚拟机并制作成模板
一.使用virt-install创建新的虚拟机 virt--template --ram --vcpu= --virt-type kvm --cdrom=/Data/kvm/iso/CentOS-.i ...