MongoDB 多对多关系的简单示例
时间:2022-05-06
本文章向大家介绍MongoDB 多对多关系的简单示例,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
例如文章的标签,一篇文章可能包含多个标签,一个标签也会对应多篇文章
这是一个多对多的映射关系,在sql中我们一般这样设计
Article:
Id
Title
...
Tag:
Id
Name
Relation:
ArticleId
TagId
通过表的连接,就可以查询出我们想要的各种数据
那么,如果用MongoDB的思想,该如何设计这种关系呢?
有一个关键点首先要知道:MongoDB中不支持文档的连接操作,所以就不能按照sql的思路来设计
设计示例
下面给出一个简单的思路
设计两个文档,文章 和 标签,每次文章添加新标签的时候,更新文章和标签的对应关系
article
{
id:"505cad",
title:"test title",
tags:["tag1","tag2"]
...
}
tag
{
tag:""
article:["article1","article2"]
size:2
}
查询示例
(1)列出所有Tag
db.article.distinct("tags")
返回数据例如:
[ "tag1", "tag2", "tag3" ]
(2)列出所有文章及其Tag
db.article.find({});
返回数据例如:
{
"_id" : ObjectId("5058878"),
"title" : "test title",
"tags" : [ "tag1", "tag2" ]
}
{ "_id" : ObjectId("505879"),
"title" : "test title2",
"tags" : [ "tag1", "tag3" ]
}
(3)列出某Tag下的所有文章
db.article.find({tags:{$in:["tag2"]}});
返回数据例如:
{
"_id" : ObjectId("5058878"),
"title" : "test title",
"tags" : [ "tag1", "tag2" ]
}
- 冷场了吗?我带着phpcms9.6.2 注入来救场了
- 厚土Go学习笔记 | 22. 实现Pic
- ie8和chrome获取上传图片的宽度和高度等尺寸
- 厚土Go学习笔记 | 21. range用法
- Golang Stub初体验
- 厚土Go学习笔记 | 20. slice 继续
- 数据挖掘算法之深入朴素贝叶斯分类
- 歪?我想要一个XXE。
- 厚土Go学习笔记 | 19. slice和数组很像,但是slice可以添加元素
- 工具| 手把手教你制作信息收集器之网站备案号
- 厚土Go学习笔记 | 18. 数组
- 厚土Go学习笔记 | 17. 结构体及用指针访问结构体
- Java枚举类型的原理
- 厚土Go学习笔记 | 27. 斐波纳契闭包
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 面经手册 · 第3篇《HashMap核心知识,扰动函数、负载因子、扩容链表拆分深度学习(+实践验证)》
- Head First设计模式——桥接模式
- Head First设计模式——生成器模式和责任链模式
- Head First设计模式——蝇量模式和解释器模式
- 【每日一题】33. Search in Rotated Sorted Array
- 【每日一题】34. Find First and Last Position of Element in Sorted Array
- 【每日一题】35. Search Insert Position
- Head First设计模式——原型模式和访问者模式
- Java 新特性前瞻:封印类
- 每天手撕一道算法题-130. 被围绕的区域
- C#实现前向最大匹、字典树(分词、检索)
- Tomcat 中文乱码,设置UTF-8
- 从零搭建Spring Boot脚手架(4):手写Mybatis通用Mapper
- IDEA将Maven项目中指定文件夹下的xml等文件编译进classes
- 数据误操作,教你使用ApexSQLLog工具从 SQLServer日志恢复数据!