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对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)

《使用Python从PPT文档中提取图片和图片信息(如坐标、宽度和高度等)》PPT是一种高效的信息展示工具,广泛应用于教育、商务和设计等多个领域,PPT文档中常常包含丰富的图片内容,这些图片不仅提升了... 目录一、引言二、环境与工具三、python 提取PPT背景图片3.1 提取幻灯片背景图片3.2 提取

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Python中判断对象是否为空的方法

《Python中判断对象是否为空的方法》在Python开发中,判断对象是否为“空”是高频操作,但看似简单的需求却暗藏玄机,从None到空容器,从零值到自定义对象的“假值”状态,不同场景下的“空”需要精... 目录一、python中的“空”值体系二、精准判定方法对比三、常见误区解析四、进阶处理技巧五、性能优化

Java利用docx4j+Freemarker生成word文档

《Java利用docx4j+Freemarker生成word文档》这篇文章主要为大家详细介绍了Java如何利用docx4j+Freemarker生成word文档,文中的示例代码讲解详细,感兴趣的小伙伴... 目录技术方案maven依赖创建模板文件实现代码技术方案Java 1.8 + docx4j + Fr

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

在java中如何将inputStream对象转换为File对象(不生成本地文件)

《在java中如何将inputStream对象转换为File对象(不生成本地文件)》:本文主要介绍在java中如何将inputStream对象转换为File对象(不生成本地文件),具有很好的参考价... 目录需求说明问题解决总结需求说明在后端中通过POI生成Excel文件流,将输出流(outputStre