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

相关文章

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Java第二阶段---09类和对象---第三节 构造方法

第三节 构造方法 1.概念 构造方法是一种特殊的方法,主要用于创建对象以及完成对象的属性初始化操作。构造方法不能被对象调用。 2.语法 //[]中内容可有可无 访问修饰符 类名([参数列表]){ } 3.示例 public class Car {     //车特征(属性)     public String name;//车名   可以直接拿来用 说明它有初始值     pu

HTML5自定义属性对象Dataset

原文转自HTML5自定义属性对象Dataset简介 一、html5 自定义属性介绍 之前翻译的“你必须知道的28个HTML5特征、窍门和技术”一文中对于HTML5中自定义合法属性data-已经做过些介绍,就是在HTML5中我们可以使用data-前缀设置我们需要的自定义属性,来进行一些数据的存放,例如我们要在一个文字按钮上存放相对应的id: <a href="javascript:" d

Python脚本:TXT文档行数统计

count = 0 #计数变量file_dirs = input('请输入您要统计的文件根路径:')filename = open(file_dirs,'r') #以只读方式打开文件file_contents = filename.read() #读取文档内容到file_contentsfor file_content in file_contents:

bcolz文档

原文:http://bcolz.blosc.org/en/latest/reference.html First level variables bcolz.__version__'''bcolz包的版本。''' bcolz.dask_here'''是否检测到dask的最低版本。''' bcolz.min_dask_version'''需要dask的最低版本(dask是可选

PHP7扩展开发之对象方式使用lib库

前言 上一篇文章,我们使用的是函数方式调用lib库。这篇文章我们将使用对象的方式调用lib库。调用代码如下: <?php $hello = new hello(); $result = $hello->get(); var_dump($result); ?> 我们将在扩展中实现hello类。hello类中将依赖lib库。 代码 基础代码 这个扩展,我们将在say扩展上增加相关代码。sa

hibernate修改数据库已有的对象【简化操作】

陈科肇 直接上代码: /*** 更新新的数据并并未修改旧的数据* @param oldEntity 数据库存在的实体* @param newEntity 更改后的实体* @throws IllegalAccessException * @throws IllegalArgumentException */public void updateNew(T oldEntity,T newEntity

WordPress开发中常用的工具或api文档

http://php.net/ http://httpd.apache.org/ https://wordpress.org/ https://cn.wordpress.org/ https://core.svn.wordpress.org/ zh-cn:开发者文档: https://codex.wordpress.org/zh-cn:%E5%BC%80%E5%8F%91%E8%80%

类和对象的定义和调用演示(C++)

我习惯把类的定义放在头文件中 Student.h #define _CRT_SECURE_NO_WARNINGS#include <string>using namespace std;class student{public:char m_name[25];int m_age;int m_score;char* get_name(){return m_name;}int set_name