Mongoose查增改删
- 在
src目录下新建一个文件夹models,用来存放数据模型和操作数据库的方法。 - 在
models目录下新建一个文件user.js,用来管理用户信息相关的数据库操作。 - 相关的数据模型和数据库操作方法,最后通过
module.exports暴露出去。
mongoose版本8.0.0
1-创建结构
const mongoose = require("mongoose");
const userSchema = new mongoose.Schema(
{
id: {
type: Number,
index: true,
unique: true,
},
name: String,
},
{
versionKey: false, // 设置false,存取数据就不会带版本id
}
);
2-创建模型
const User = mongoose.model("user", userSchema);
3-查增改删
查
批量查询Model.find()
Model.find(filter [, projection] [, options])
await User.find({ name: 'kaka' }, 'name phone'); // 字段前加'-'表示不返回的字段
await User.find({}, { name: 1, phone: 1 }); // 1-要返回的字段 0-不返回的字段
- filter:过滤项。
- projection:<Object|String|Array[String]>要返回的可选字段。
- options:配置项,参见Query - Mongoose 中文网 (nodejs.cn)。
可以包在函数里,最后通过
module.exports把函数暴露出去。// 查
function FindUserList() {
return User.find();
}
单个查询Model.findOne()
Model.findOne([conditions] [, projection] [, options])
await User.findOne({ id: 1 }, { name: 1, id: 1 });
- conditions:查询条件。
- projection:<Object|String|Array[String]>要返回的可选字段。
- options:配置项,参见Query - Mongoose 中文网 (nodejs.cn)。
增
新增文档Model.create()
Model.create(docs [, options])
await User.create({ name: 'gaga' });
await User.create([{ name: 'mama' }, { name: 'nana' }]);
- docs:<Array|Object>要插入的文档。
- options:配置项,参见Model - Mongoose 中文网 (nodejs.cn)
改
修改文档Model.findOneAndUpdate()
Model.findOneAndUpdate([conditions] [, update] [, options])
const options = {
new: true,
strict: true,
};
await User.findOneAndUpdate({ id: 1 }, { id: 1, name: 'newName' }, options);
- conditions:查询条件。
- update:新的文档。
- options:配置项,参见Model - Mongoose 中文网 (nodejs.cn)
options.strict:覆盖模式的严格模式选项(默认启用),可确保传递给模型构造函数的、结构中未指定的值不会保存到数据库中。options.upsert:默认为false。如果为true,并且没有找到文档,则插入新文档。options.projection:可选字段返回。- options.new:默认为
false。如果为true,则返回修改后的文档,而不是原始文档。
删
删除文档Model.findOneAndDelete()
Model.findOneAndDelete(conditions [, options])
await User.findOneAndDelete({ id: 1 });
- conditions:查询条件。
- options:配置项,参见Query - Mongoose 中文网 (nodejs.cn)
options.strict:覆盖模式的严格模式选项(默认启用)。options.projection:可选字段返回。options.session:与此查询关联的会话,参见事务 - Mongoose 中文网 (nodejs.cn)。
完整代码
// src/models/user.js
const mongoose = require("mongoose");
const userSchema = new mongoose.Schema(
{
id: {
type: Number,
index: true,
unique: true,
},
name: String,
},
{
versionKey: false,
}
);
const User = mongoose.model("user", userSchema);
// 查-列表
function FindUserList() {
return User.find();
}
// 查
function FindUser(id) {
return User.findOne({ id });
}
// 改
function UpdateUser(id, update) {
const options = {
new: true,
strict: true,
};
return User.findOneAndUpdate({ id }, update, options);
}
// 增
function AddUser(user) {
return User.create(user);
}
// 删
function DeleteUser(id) {
return User.findOneAndDelete({ id });
}
module.exports = {
User,
FindUserList,
FindUser,
UpdateUser,
AddUser,
DeleteUser,
};
Mongoose查增改删的更多相关文章
- DataFrame查增改删
DataFrame查增改删 查 Read 类list/ndarray数据访问方式 dates = pd.date_range(',periods=10) dates df = pd.DataFrame ...
- XML简单的增改删操作
XML文件的简单增改删,每一个都可以单独拿出来使用. 新创建XML文件,<?xmlversion="1.0"encoding="utf-8"?> & ...
- js 属性增改删操作
js 属性增改删操作,可参看菜鸟教程,这里记录一个小问题:disabled属性 使用setAttribute操作无法 禁用disabled属性,需使用removeAttribute操作,原因是只要有d ...
- mongoose 实现 增、删、改、查
mongoose常用的API 增 save是一个实例方法,使用时需要先 new Model() 来实例化 //保存一个用户信息,userobj为你创建的文档对象模型里的字段,需正确对应传入 const ...
- python数据类型—列表(增改删查,统计,取值,排序)
列表是最常用的数据类型之一,通过列表可以对数据实现方便的存储,修改等操作. 先声明一个空列表: >>> names = [] >>> names [] 可以存多个值 ...
- oracle函数自治事务解决不能增改删的语句操作
CREATE OR REPLACE FUNCTION SEQ3 (v_bname in VARCHAR2) return NUMBER is pragma autonomous_transaction ...
- EF6增改删等常用基类
using System; using System.Linq; using System.Threading.Tasks; using System.Linq.Expressions; using ...
- WPF中DataGrid的应用-绑定,增改删,分页,样式
参考以下网址: http://www.cnblogs.com/fwbnet/archive/2012/05/08/2490974.html
- Linq To Sql 增改删
using System; using System.Data.Linq.Mapping; namespace ConsoleApplication3 { [Table(Name = "te ...
- MongoDB 基本操作(增改删)
1.插入数据 和关系型数据库一样,增加数据记录可以使用insert语句,这是很简单的. 当插入数据时,如果此集合不存在,则MongoDB系统会自动创建一个集合,即不需要刻意预先创建集合 每次插入数据时 ...
随机推荐
- 让 GPT-4 来修复 Golang “数据竞争”问题 - 每天5分钟玩转 GPT 编程系列(6)
目录 1. Golang 中的"数据竞争" 2. GoPool 中的数据竞争问题 3. 让 GPT-4 来修复数据竞争问题 3.1 和 GPT-4 的第一轮沟通 3.2 和 GPT ...
- 9、Mybatis之动态SQL
9.1.环境搭建 9.1.1.创建新module 创建名为mybatis_dynamicSQL的新module,过程参考5.1节 9.1.2.创建Emp实体类 package org.rain.myb ...
- Job System 初探
作者:i_dovelemon 日期:2023-08-24 主题:Fiber, Atomic Operation, MPMC Queue, Multiple thread, Job system 引言 ...
- Python 基础面试第三弹
1. 获取当前目录下所有文件名 import os def get_all_files(directory): file_list = [] # os.walk返回一个生成器,每次迭代时返回当前目录路 ...
- charts自适应
大屏echarts自适应文字大小 1.在utils中创建 setFontSize.js function setFontSize(val) { const baseSize = 50; let sca ...
- 从DevOps实践落地的角度谈谈“流程”和“规范"的反模式
最近在经历的一些事情,让我突发灵感,觉得要写点关于DevOps体系建设过程中的"流程规范",记录下来. 如何解读"流程规范" 谈到DevOps落地,无一例外都会 ...
- 「acmhdu - 6314」Matrix
link. 首先将问题弱化为 1-d,我们待定容斥系数 \(f_i\),可以写出答案的式子:\(\sum\limits_{i=a}^nf_i\binom{n}{i}2^{n-i}\).解释就是,我们想 ...
- Solution -「洛谷 P5610」「YunoOI 2013」大学
Description Link. 区间查 \(x\) 的倍数并除掉,区间查和. Solution 平衡树. 首先有个基本的想法就是按 \(a_{i}\) 开平衡树,即对于每个 \(a_{i}\) 都 ...
- MySQL运维1-日志
一.错误日志 错误日志是MySQL中最重要的日志之一,它记录了当MySQL启动和停止时,以及服务器在运行过程中发生的任何严重错误时的相关信息,当数据库出现任何故障导致无法正常使用时,建议首先查看此日志 ...
- Python网络编程——操作系统基础、网络通信原理、.网络通信实现、DNS域名解析、 网络通信流程
文章目录 一.操作系统基础 二.网络通信原理 2.1 互联网的本质就是一系列的网络协议 2.2 osi七层协议 2.3 tcp/ip五层模型讲解 2.3.1 物理层 2.3.2 数据链路层 2.3.3 ...