首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MongoDB增删改查操作

// mongoose.Schema() 是一个构造函数,要new一个实例对象 //2、设定集合规则 const courseSchema = new mongoose.Schema({ name...实际在数据库中产生的集合名为courses 2.创建文档 创建文档实际上就是向集合中插入数据。 方法1 分为两步: ①创建集合实例。 ②调用实例对象下的save方法将数据保存到数据库中。...: true }); // 调用实例对象下的save方法将数据保存到数据库中。...(result); }); ​ // 删除多个 如果条件为空,默认删除所有文档 返回一个对象,n代表删除的文档数,OK表示是否删除成功 User.deleteMany({}).then(result...,例如文章信息和用户信息存储在不同集合中,但文章是某个用户发表的 要查询文章的所有信息包括发表用户,就需要用到集合关联。

6.5K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MongoDB数据库基本操作

    默认返回当前集合中的第一条文档 // User.findOne({name: '李四'}).then(result => console.log(result)) // 查询用户集合中年龄字段大于20...('User', userSchema); // 查找到一条文档并且删除 // 返回删除的文档 // 如何查询条件匹配了多个文档 那么将会删除第一个匹配的文档 // User.findOneAndDelete...('User', userSchema); // 找到要删除的文档并且删除 // 返回是否删除成功的对象 // 如果匹配了多条文档, 只会删除匹配成功的第一条文档 // User.updateOne({...({ title: { type: String, // 必选字段 required: [true, '请传入文章标题'], // 字符串的最小长度 minlength: [2, '文章长度不能小于...2'], // // 字符串的最大长度 maxlength: [5, '文章长度最大不能超过5'], // // 去除字符串两边的空格 trim: true }, age: { type:

    4.2K10

    Mongoose 实现关联查询和踩坑记录

    本文源自工作中的一个问题,在使用 Mongoose 做关联查询时发现使用 populate() 方法不能直接关联非 _id 之外的其它字段,在网上搜索时这块的解决方案也并不是很多,在经过一番查阅、测试之后...文档内嵌与引用模式 MongoDB 是一种文档对象模型,使用起来很灵活,它的文档结构分为 内嵌和引用 两种类型。...$lookup.foreignFiled: 被 Join 的集合的字段,本示例中是 Books 表的 bookId 字段。 $as: 别名,关联查询返回的这个结果起一个新的名称。...如果需要指定哪些字段返回,哪些需要过滤,可定义 $project 对象,关联查询的字段过滤可使用 别名.关联文档中的字段 进行指定。...表示的要 Join 的集合的名称,同 $lookup.from justOne: 默认为 false 返回多条数据,如果设置为 true 就只会返回一条数据 AuthorSchema.virtual('

    26.5K20

    你真的了解mongoose吗?

    字段(也称为查询“投影”),必须同时指定包含或同时指定排除,不能混合指定,_id除外。...limit: 指定返回结果的最大数量 skip: 指定要跳过的文档数量 lean: 返回普通的 js 对象,而不是 Mongoose Documents。...而 findById(undefined) 相当于 findOne({ _id: null }),返回 null。 查询结果: 返回数据的格式是 {} 对象形式。...查询结果: 返回数据的格式是 {} 对象形式。 有多个数据满足查询条件的,只返回第一条。 查询条件 conditions 为 {}、 null 或 undefined,将任意返回一条数据。...result 查询结果: 返回数据的格式是 {} 对象形式。 id 为 undefined 或 null,result 返回 null。 没符合查询条件的数据,result 返回 null。

    41.6K30

    MongoDB增删改查操作

    // mongoose.Schema() 是一个构造函数,要new一个实例对象 //2、设定集合规则 const courseSchema = new mongoose.Schema({ name...: true }); // 调用实例对象下的save方法将数据保存到数据库中。...在项目根目录下输入以下命令导入 mongoimport -d 数据库名称 -c 集合名称 --file 要导入的数据文件 4.查询文档 find()方法 返回一组文档 // 根据条件查找文档(条件为空则查找所有文档...(result); }); ​ // 删除多个 如果条件为空,默认删除所有文档 返回一个对象,n代表删除的文档数,OK表示是否删除成功 User.deleteMany({}).then(result...使用id对集合进行关联 使用populate方法进行关联集合查询 // 关联集合 ​ const mongoose = require('mongoose'); // 连接数据库 mongoose.connect

    6.2K10

    深入浅出mongodb(一)

    image.png 1.3 数据库的基本操作 显示表 show dbs; 切换数据库 use test; 插入数据 db.test.insert({name:"vivo"}); 查询数据 db.test.find...2.4 Schema 定义 Schema 来说其实是用来定义文档的基本字段和集合,也可以理解为表结构的定义。Schema 是与数据无关的 并不能直接操作数据库。...更多的文档参考https://mongoosejs.com/docs/schematypes.html[5] ?有人可能会问为什么 ObjectId 可以做唯一标识符呢,不会重复吗?...Model 模型是操作数据库最直接的部分,它代表整个集合 ,操作对象是整个集合。...第二种写法是返回promise 上述定义 model 的方法是通过 model 类创建的,还有一种创建 model 的方法是通过实例创建,这个创建出来的是一个操作对象,代表是一个单个文档只能操作自己。

    4K10

    大数据技术之_22_MongoDB学习_MongoDB 的简介、下载、安装、启动、配置和关闭 + MongoDB 的基本操作 + Mongoose + 使用 java 对 MongoDB 增删改查

    删除数据是永久的,不能撤销。...查询的方法:     Model.find(conditions, [projection], [options], [callback])         - 查询所有符合条件的文档,总会返回一个数组...([conditions], [projection], [options], [callback])         - 查询符合条件的第一个文档,总会返回一个具体的文档对象     参数解释:          ...err) {         // console.log(doc);         // 通过 find() 查询的结果,返回的对象就是 Document 对象或 Document 对象数组。         ...- 将 Document 对象转换为一个普通的 js 对象。转换为普通的 js 对象以后,所有的 Document 对象的方法或属性都不能使用了。

    17.8K30

    架构和数据库

    .find({}) 可以接受一个对象作为条件参数 {属性名1:值,属性名2:值} 查询属性是指定值的文档 db..findOne({}) 用来查询集合中符合条件的第一个文档 db.....find({}).count() 查询所有结果的数量 修改集合中符合条件的文档 db..update({查询条件},{新对象},{配置}) 默认只修改一个 db.....updateOne({查询条件},{新对象}) 修改一个符合条件的文档 db..updateMany({查询条件},{新对象}) 同时修改多个符合条件的文档 db.....replaceOne({查询条件},{新对象}) 替换一个符合条件的文档 默认使用新对象替换旧对象 如果需要修改指定的属性,而不是替换,需要使用“修改操作符”来完成修改 db.person.update...查询结果结果会通过回调函数返回,参数必选,不传没有返回值 通过 find() 查询的结果,返回的对象就是 Document,文档对象 Document 对象是 Model 的实例 doc instanceof

    8010

    04_数据库

    .find({}) 可以接受一个对象作为条件参数 {属性名1:值,属性名2:值} 查询属性是指定值的文档 db.....update({查询条件},{新对象},{配置}) 默认只修改一个 db..updateOne({查询条件},{新对象}) 修改一个符合条件的文档 db.....updateMany({查询条件},{新对象}) 同时修改多个符合条件的文档 db.....replaceOne({查询条件},{新对象}) 替换一个符合条件的文档 默认使用新对象替换旧对象 如果需要修改指定的属性,而不是替换,需要使用“修改操作符”来完成修改 $set 可以修改文档中的指定属性...查询结果结果会通过回调函数返回,参数必选,不传没有返回值 通过 find() 查询的结果,返回的对象就是 Document,文档对象 Document 对象是 Model 的实例 doc instanceof

    7010

    mongoose官方文档总结

    v.indexOf(' ') + 1); }); axl.fullName = 'William Rose'; // Now `axl.name.first` is "William" 再次强调,虚拟值不能用于查询和字段选择...如果想更新单独一条文档并且返回给应用层,可以使用 findOneAndUpdate 方法。 六、文档-Documents Mongoose document代表着MongoDB文档的一对一映射。...= new Schema({ children:[childSchema], child:childSchema }) 子文档与文档的区别是 子文档不能单独保存,他们会在他们的顶级文档保存时保存...Model的多个静态辅助方法都可以查询文档 Query实例有一个.then()函数,用法类似Promise 我们看一下demo,查询persons表中name中属性last为Ghost值的文档,只查询...返回的一切对象: const mongoose = require('mongoose') const Schema = mongoose.Schema; const personSchema =

    20.6K40

    Mongoose学习参考文档

    ,第二个参数是更新的对象,但不能更新主键,这就是为什么要删除主键的原因。   ...第二个参数是更新的数量,如果要返回更新后的对象,则要使用如下方法 Person.findByIdAndUpdate(_id,{$set:{name:'MDragon'}},function(err...JSON对象,不能是由Model创建的实体,原因是:由Model创建的实体krouky虽然打印是只有{name:'krouky'},但是krouky属于Entity,包含有Schema属性和Model数据库行为模型...,分的比较明细,如果不带callback,则返回query,query没有执行的预编译查询语句,该query对象执行的方法都将返回自己,只有在执行exec方法时才执行查询,而且必须有回调。   ...} }); 7.2 验证失败   如果验证失败,则会返回err信息,err是一个对象该对象属性如下 err.errors //错误集合(对象)

    24.2K90

    GraphQL 基础实践

    先看右边的 Schema:type 是 GraphQL Schema 中最基本的一个概念,表示一个 GraphQL 对象类型,可以简单地将其理解为 JavaScript 中的一个对象,在 JavaScript...后者表示movies中返回的 Movie 元素不能为空,但 movies字段的返回是可以为空的。 你可能在请求体中注意到,genre 参数的值没有被双引号括起来,也不是任何内置类型。...在本例中,定义了一个Basic接口,Song以及Video类型都要实现该接口的字段。然后在search查询中返回该接口。 searchMedia查询返回一组Basic接口。...Resolver 对应着 Schema 上的字段,当请求体查询某个字段时,对应的 Resolver 函数会被执行,由 Resolver 函数负责到数据库中取得数据并返回,最终将请求体中指定的字段返回。...id 查询一遍得出结果,最终返回的数据就能符合 Schema 的定义了。

    12.8K20

    如何使用Mongoose创建一个数据处理的模块

    比如,在没有使用 Mongoose 的情况下,可能会在数据库中存储各种格式不一致的用户数据,而使用 Mongoose 后,所有用户数据都必须符合预定义的 Schema 结构,保证了数据的一致性。...这些方法使得开发者无需编写复杂的原生 MongoDB查询语句,降低了开发难度。链式调用和查询构建器:支持链式调用和查询构建器,可以灵活地构建复杂的查询条件。...3、支持异步操作Promise 支持:Mongoose 的操作方法返回 Promise 对象,方便使用 async/await 语法进行异步操作。避免了回调地狱问题,提高了代码的可维护性。...错误处理: 使用 async/await 时,可以通过 try/catch 语句块集中处理错误,统一返回错误信息。...");}调用 main 函数,并处理其返回的 Promisemain() .then((res) => { console.log("数据库连接成功"); }) .catch((err) =

    7410

    MongDB删除文档和更新文档

    ('User', userSchema); // 查找到一条文档并且删除 // 返回删除的文档 // 如何查询条件匹配了多个文档 那么将会删除第一个匹配的文档 // User.findOneAndDelete...删除多条文档 // {} 即删除所有文档 User.deleteMany({}).then(result => console.log(result)) // 更新单个 User.updateOne({查询条件...}, {要修改的值}).then(result => console.log(result)) // 更新多个 User.updateMany({查询条件}, {要更改的值}).then(result...=> console.log(result)) // 引入mongoose第三方模块 用来操作数据库 const mongoose = require('mongoose'); // 数据库连接 mongoose.connect...('User', userSchema); // 找到要删除的文档并且删除 // 返回是否删除成功的对象 // 如果匹配了多条文档, 只会删除匹配成功的第一条文档 // User.updateOne({

    2.9K10

    【GraphQL】225-GraphQL真香入门教程

    , buildSchema() 方法需要传入的参数是字符串类型,如下面的 hero 查询字段,后面的 String 类型表示字段返回的数据类型: const schema = buildSchema(`...GraphQL 查询能够遍历相关对象及其字段,使得客户端可以一次请求查询大量相关数据,而不像传统 REST 架构中那样需要多次往返查询。...我们可以新建一个查询类型来定义 user 字段返回的类型: const schema = buildSchema(` type User { # 查询可以有备注!...自定义返回类型 在实际开发中,我们返回的数据类型可能是一个对象,对象中可能既有 Int 类型的属性,也有 String 类型的值,等等,这里我们可以使用 自定义返回类型 来处理: //...省略其他 const...属性上 属性定义 定义在类型后,键值对形式 定义在参数对象 fields 属性中,值为对象,每个属性名为键名,值也是对象,其中 type属性的值为 graphql 中的属性,下面会补充 补充: fields

    8.1K21

    GraphQL真香入门教程

    , buildSchema() 方法需要传入的参数是字符串类型,如下面的 hero 查询字段,后面的 String 类型表示字段返回的数据类型: const schema = buildSchema(`...GraphQL 查询能够遍历相关对象及其字段,使得客户端可以一次请求查询大量相关数据,而不像传统 REST 架构中那样需要多次往返查询。...我们可以新建一个查询类型来定义 user 字段返回的类型: const schema = buildSchema(` type User { # 查询可以有备注!...自定义返回类型 在实际开发中,我们返回的数据类型可能是一个对象,对象中可能既有 Int 类型的属性,也有 String 类型的值,等等,这里我们可以使用 自定义返回类型 来处理: //...省略其他 const...类名 跟在 type 字符后面,这里是 typeHero 在参数对象的 name 属性上 属性定义 定义在类型后,键值对形式 定义在参数对象 fields 属性中,值为对象,每个属性名为键名,值也是对象

    7.3K30
    领券