使用Mongoose populate实现多表关联存储与查询,内附完整代码

这篇具有很好参考价值的文章主要介绍了使用Mongoose populate实现多表关联存储与查询,内附完整代码。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

mongoose populate,MongoDB教程,mongodb,数据库,mongoose,populate,大数据


使用Mongoose populate实现多表关联与查询

mongodb不是传统的关系型数据库,我们可以使用monogoose方便的将多个表关联起来,实现一对多、多对多的数据表存储和查询功能。
本文已最常见的一对多关系模型,介绍简单的数据模型定义、存储、查询。

一、 数据模型创建

我们创建一个Person模型和一个Story模型,其中一个Person对应多个Story,也就是典型的一对多关系。

1. 创建一个PersonSchema

创建PersonSchema时,不需要为其指定_id属性,因为数据库会自动为其添加主键属性。
由于一个Person对象可以拥有多个Story对象,所以需要添加一个stories数组属性,存储与其关联的Story
具体代码如下:

const PersonSchema = new Schema({
    // _id: Schema.Types.ObjectId, 
    name: String,
    age: Number,
    stories: [{ type: Schema.Types.ObjectId, ref: 'Story' }]
})

问题解答
其中的Schema.Types.ObjectId是一种内置的特殊类型,专门用来表示对象的ID
官方解读:An ObjectId is a special type typically used for unique identifiers.

2. 创建一个StorySchema

每个Story都有一个唯一的author,也就是一个Person对象。和普通的属性不同的是,我们需要指定引用属性的类型和引用的模型名称。同样的,每个Story对象还可以拥有多个fans,同样是Person对象。这里实际上有一个循环的引用。
如果学习过关系型数据库的同学,可能对这里非常容易了解。

const StorySchema = new Schema({
    author: { type: Schema.Types.ObjectId, ref: 'Person' },
    title: String,
    fans: [{ type: Schema.Types.ObjectId, ref: 'Person' }]
})

3. 使用Schema创建对应的model

创建模型需要使用mongoose.model方法,该方法可以接收三个参数,其中:

  1. 第一个参数指模型的名称
  2. 第二个参数指使用的Schema
  3. 第三个参数指对应的mongodb数据表(集合)
    以下代码分别使用StorySchemaPersonSchema创建了一个Story模型和一个Person模型
const Story = mongoose.model('Story', StorySchema, 'tb_story')
const Person = mongoose.model('Person', PersonSchema, 'tb_person')

二、数据存储

使用mongoose可以非常简单的使用面向对象的方式完成数据的存取。

1. 创建模型实例

创建一个名为xiaomingPerson对象,然后再创建一个Story,并使其引用Person._id属性。

let p1 = new Person({
    name: 'xiaoming',
    age: 12
})
let s1 = new Story({
    title: 'The life of snow white and the dwarfs',
    author: p1._id
})
s1.fans.push(p1.id)

问题解读
这里有一个不符合常理的地方,就是我在这里把故事的作者设为了故事的粉丝~~

2. 存储模型数据

使用模型的.save()方法存储对象的数据到数据库中。

p1.save().then(person => {
    console.log('Pserson save success.\n', person)
    s1.save().then(story => {
        console.log('Story save success.\n', story)
    })
})

代码指向结果如下:

Pserson save success.
 {
  name: 'xiaoming',
  age: 12,
  stories: [],
  _id: new ObjectId("62ef6fb11c8795f4e1327adb"),	  //注意,这里对应了下面的Story.author
  __v: 0
}
Story save success.
 {
  author: new ObjectId("62ef6fb11c8795f4e1327adb"),   //注意,这里对应了上面的Person._id
  title: 'The life of snow white and the dwarfs',
  fans: [ new ObjectId("62ef6fb11c8795f4e1327adb") ],
  _id: new ObjectId("62ef6fb11c8795f4e1327adc"),
  __v: 0
}

这样数据存储工作就完成了。

三、数据关联查询

  1. 使用故事的标题,查询故事作者的名称
Story.findOne({ title: 'The life of snow white and the dwarfs' })
    .populate('author').then(story => {
        console.log(story.author.name)
    })

执行结果会输出:xiaoming
2. 使用故事标题,查询粉丝信息

Story.findOne({ title: 'The life of snow white and the dwarfs' })
	.populate('fans').then(story => {
    	console.log(story.fans)
	})

代码执行结果:文章来源地址https://www.toymoban.com/news/detail-780567.html

[
	 {
	  name: 'xiaoming',
	  age: 12,
	  stories: [],
	  _id: new ObjectId("62ef781a8123a8ec47f40736"),
	  __v: 0
	}
]

四、完整代码

const mongoose = require('mongoose')
const Schema = mongoose.Schema

mongoose.connect('mongodb://ahohAdmin:123456@localhost:27017/db_ahoh')
    .then('database connected')
    .catch(err => console.log(err))

const PersonSchema = new Schema({
    // _id: Schema.Types.ObjectId,
    name: String,
    age: Number,
    stories: [{ type: Schema.Types.ObjectId, ref: 'Story' }]
})

const StorySchema = new Schema({
    author: { type: Schema.Types.ObjectId, ref: 'Person' },
    title: String,
    fans: [{ type: Schema.Types.ObjectId, ref: 'Person' }]
})

const Story = mongoose.model('Story', StorySchema, 'tb_story')
const Person = mongoose.model('Person', PersonSchema, 'tb_person')


let p1 = new Person({
    name: 'xiaoming',
    age: 12
})
let s1 = new Story({
    title: 'The life of snow white and the dwarfs',
    author: p1._id
})
s1.fans.push(p1.id)
p1.save().then(person => {
    console.log('Pserson save success.\n', person)
    s1.save().then(story => {
        console.log('Story save success.\n', story)

    })
})

Story.findOne({ title: 'The life of snow white and the dwarfs' })
    .populate('author').then(story => {
        console.log(story.author.name)
    })

Story.findOne({ title: 'The life of snow white and the dwarfs' }).populate('fans').then(story => {
    console.log(story.fans)
})

到了这里,关于使用Mongoose populate实现多表关联存储与查询,内附完整代码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • mybatis-plus 多表关联条件分页查询

    此处以一对多,条件分页查询为例: 主表 明细表 0.请求dto 1.Controller 层: 注:我的项目中进行了service 读写分类配置,实际使用中,直接使用mybatis-plus中的 IUserService 对应的接口就行。 2.service 层 service impl实现层: 3.mapper 层 4.mapper.xml层 5.测试: 结果body: Q:todo page 分页会把

    2024年02月12日
    浏览(47)
  • MySQL---多表联合查询(下)(内连接查询、外连接查询、子查询(ALL/ANY/SOME/IN/EXISTS关键字)、自关联查询)

    1. 内连接查询 数据准备: 内连接查询语法: 2. 外连接查询 语法: 左外连接: left outer join:             select * from A left outer join B on 条件 ;             右外连接: right outer join:             select * from A right outer join B on 条件 ;             满外连接 : full out

    2024年02月04日
    浏览(52)
  • spring boot集成mybatis-plus——Mybatis Plus 多表联查(包含分页关联查询,图文讲解)...

     更新时间 2023-01-03 21:41:38 大家好,我是小哈。 本小节中,我们将学习如何通过 Mybatis Plus 实现 多表关联查询 ,以及 分页关联查询 。 本文以 查询用户所下订单 ,来演示 Mybatis Plus 的关联查询,数据库表除了前面小节中已经定义好的用户表外,再额外创建一张订单表,然后

    2024年02月01日
    浏览(89)
  • MySQL基础篇补充 | 多表查询中使用SQL99实现7种JOIN操作、SQL99语法新特性

    目录 一:多表查询中使用SQL99实现7种JOIN操作  二:SQL99语法新特性 1. 自然连接Natural 2. USING连接 在多表查询中,除了遇到最多的内连接、左外连接和右外连接,还有其它的连接方式;接下来就聊聊其它的连接方式,如下图:  ​​​​​​ 并且在正式讲解之前,需要先了解

    2024年02月03日
    浏览(45)
  • SQL语句 - 多表查询使用详细介绍

    例如我们有一张员工表和部门表, 员工表有6条数据, 部门表表有4条数据 : 使用多表查询, 查询员工表和部门表两张表 : 此时查询到的结果会有24条数据, 为什么会这样呢 ? 笛卡尔积:有A, B两个集合, 取A, B集合所有组合情况(4*6=24); 我们多表查询, 更多的是消除这些无效的数据 例

    2024年01月16日
    浏览(48)
  • HIVE 3 使用 MR 引擎多表关联 (JOIN) 导致丢数的问题复现、问题根源及解决方案 (附代码)

    本文意图解决 HIVE 3 版本中使用 MR 作为运算引擎进行 JOIN 操作时导致的丢数情况。 Apache Hive 在 2.3 版本后宣布放弃维护 MapReduce 作为底层执行引擎,并转而使用 Tez 作为默认的查询引擎。但是由于 Tez 在大作业量和高并发时的严重性能问题,导致许多任务不得不继续使用 MapRe

    2024年02月13日
    浏览(36)
  • MyBatis(多表查询,动态SQL的使用)

    目录 多表查询  查询文章详情 查询一个用户底下的所有文章 动态SQL的使用 if 标签 trim 标签  where 标签 set 标签 foreach 标签 现在有俩张表,一张是 文章表 ,一张是 用户表 .如下: 我们现在想查询得到一张表,表里面的内容和文章表大多一致,只是要 在文章表的基础上添加用户表中

    2024年02月10日
    浏览(45)
  • [MySql]实现多表查询-一对一,一对多

    目录 多表关联关系的分类 mybatis中的多表查询: 数据库准备  项目目录  一对一查询(多对一) 方式一:(xml文件映射) 查询结果:  方式二:(注解映射)  一对多查询(一对多) 方式一:(xml文件映射)  方式二:(注解映射) 既然数据库是存储项目中的数据的,项目中的

    2023年04月10日
    浏览(50)
  • 在nodejs中使用Mongoose和MongoDB实现curd操作

    在 Node.js 中,数据库被用来存储和检索 Web 应用程序的数据。它们是构建动态和可伸缩应用程序的重要组成部分。 Node.js 提供了各种模块和包,可以与数据库一起工作,如 MySQL 、 PostgreSQL 、 MongoDB 等。它们允许开发人员使用各种操作来存储、查询和操作数据,例如创建、读取、

    2024年02月06日
    浏览(36)
  • 模仿Activiti工作流自动建表机制,实现Springboot项目启动后自动创建多表关联的数据库与表的方案

    文/朱季谦 熬夜写完,尚有不足,但仍在努力学习与总结中,而您的点赞与关注,是对我最大的鼓励! 在一些本地化项目开发当中,存在这样一种需求,即开发完成的项目,在第一次部署启动时,需能自行构建系统需要的数据库及其对应的数据库表。 若要解决这类需求,其实

    2024年01月24日
    浏览(52)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包