Mongoose 对象文档模型库

2023-12-12 09:04

本文主要是介绍Mongoose 对象文档模型库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、介绍

Mongoose是一个对象文档模型库,官网:http://www.mongoosejs.net/

二、作用

方便使用代码操作Mongodb数据库

三、使用流程

//1. 安装 mongoose
//2. 导入 mongoose
const mongoose = require('mongoose');
//3. 连接数据库
mongoose.connect('mongodb://127.0.0.1:27017/bilibili');
//4. 设置连接回调
//连接成功
mongoose.connection.on('open', () => {console.log('连接成功');//5. 创建文档结构对象let BookSchema = new mongoose.Schema({title: String,author: String,price: Number});//6. 创建文档模型对象let BookModel = mongoose.model('book', BookSchema);//7. 插入文档BookModel.create({title: '西游记',author: '吴承恩',price: 19.9}, (err, data) => {if (err) throw err;//输出 data 对象console.log(data);//8. 断开连接mongoose.disconnect();});
});
//连接出错
mongoose.connection.on('error', () => {console.log('连接出错~~');
})
//连接关闭
mongoose.connection.on('close', () => {console.log('连接关闭');
})

四、字段类型

类型描述
String字符串
Number数字
Boolean布尔值
Array数组,也可以使用 [] 来标识
Date日期
BufferBuffer 对象
Mixed任意类型,需要使用 mongoose.Schema.Types.Mixed 指定
ObjectId对象 ID,需要使用 mongoose.Schema.Types.ObjectId 指定
Decimal128高精度数字,需要使用 mongoose.Schema.Types.Decimal128 指定

五、字段验证

Mongoose 有一些内建验证器,可以对字段值进行验证

5.1 必填项

title: {
type: String,
required: true // 设置必填项
}

5.2 默认值

author: {
type: String,
default: '匿名' //默认值
},

5.3 枚举项

gender: {
type: String,
enum: ['男','女'] //设置的值必须是数组中的
},

5.5 唯一值

username: {
type: String,
unique: true
},

六、CURD

数据库的基本操作包括四个,增加(create),删除(delete),修改(update),查(read)

6.1 增加

插入一条

SongModel.create({title: '给我一首歌的时间',author: 'Jay'
}, function(err, data) {//错误console.log(err);//插入后的数据对象console.log(data);
});

插入多条

PhoneModel.insertMany([{brand: '华为',color: '灰色',price: 2399,tags: ['电量大', '屏幕大', '信号好']},{brand: '小米',color: '白色',price: 2099,tags: ['电量大', '屏幕大', '信号好']}
], (err, data) => {if (err) throw err;console.log('写入成功');mongoose.connection.close();
})

6.2 删除

删除一条数据

SongModel.deleteOne({_id: '5dd65f32be6401035cb5b1ed'
}, function(err) {if (err) throw err;console.log('删除成功');mongoose.connection.close();
});

删除多条

SongModel.deleteMany({author: 'Jay'
}, function(err) {if (err) throw err;console.log('删除成功');mongoose.connection.close();
});

6.3 更新

   //更新一条数据  第一个参数是需要更新的对象,第二个参数是要更新的字段BookModel.updateOne({name:'秋园'},{price:8}).then(res=>{console.log(res)})//更新多条BookModel.updateMany({author:'余华'},{is_hot:false}).then(res=>{console.log(res)})

6.4 查询

SongModel.findOne({author: '王力宏'
}, function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
//根据 id 查询数据
SongModel.findById('5dd662b5381fc316b44ce167', function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
//不加条件查询
SongModel.find(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});
//加条件查询 第一个参数是查询条件
SongModel.find({author: '王力宏'
}, function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});

七、条件控制

7.1 运算符

在 mongodb 不能 > < >= <= !== 等运算符,需要使用替代符号

  • > 使用 $gt
  • < 使用 $lt
  • >= 使用 $gte
  • <= 使用 $lte
  • !== 使用 $ne
db.students.find({id:{$gt:3}}); id号比3大的所有的记录

 7.2 逻辑运算

$or 逻辑或的情况

//查找年龄为18或者24的学生
db.students.find({$or:[{age:18},{age:24}]}); 

$and 逻辑与的情况

//查找年龄大于15并且小于20的学生
db.students.find({$and: [{age: {$lt:20}}, {age: {$gt: 15}}]});

7.3 正则匹配

条件中可以直接使用 JS 的正则语法,通过正则可以进行模糊查询

db.students.find({name:/imissyou/});

八、个性化读取

8.1 字段筛选

//0:不要的字段
//1:要的字段
SongModel.find().select({_id: 0,title: 1
}).exec(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});

8.2 数据排序

//sort 排序
//1:升序
//-1:倒序
SongModel.find().sort({hot: 1
}).exec(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});

8.3 数据截取

//skip 跳过 limit 限定
SongModel.find().skip(10).limit(10).exec(function(err, data) {if (err) throw err;console.log(data);mongoose.connection.close();
});

这篇关于Mongoose 对象文档模型库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/484029

相关文章

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

Python Pillow 库详解文档(最新推荐)

《PythonPillow库详解文档(最新推荐)》Pillow是Python中最流行的图像处理库,它是PythonImagingLibrary(PIL)的现代分支和继承者,本文给大家介绍Pytho... 目录python Pillow 库详解文档简介安装核心模块架构Image 模块 - 核心图像处理基本导入

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

C#之List集合去重复对象的实现方法

《C#之List集合去重复对象的实现方法》:本文主要介绍C#之List集合去重复对象的实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C# List集合去重复对象方法1、测试数据2、测试数据3、知识点补充总结C# List集合去重复对象方法1、测试数据

C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2