帮助中心/最新通知

质量为本、客户为根、勇于拼搏、务实创新

< 返回文章列表

【服务器相关】MongoDB进阶之动态字段设计详解

发表时间:2025-06-16 03:46:00 小编:主机乐-Yutio

本文主要介绍的是关于MongoDB动态字段设计的相关资料,分享出来供大家参考学习,需要的朋友们下面来一起看看详细的介绍吧。

适宜读者人群

  • MongoDB开发者

基础需求

产品: “我们要为现有的表单增加一个伟大的功能, 允许用户增加想要的字段”

技术目标version 1

存储动态表单数据(新增字段无需修改Schema)

首先讲一讲MongoDB支持的索引有哪几种

普通字段索引

技术目标version2

增加字段同时还要可以索引

解决方案

  • 使用数组来存储动态字段
  • 增加描述collection用来记录用户的表单配置

存储结构如下:

注意!!! 当用户增加n个字段时, 描述collection同时增加n个文档

如何查询排序筛选呢

继续深入

产品: “我们需要允许用户增加下拉框和多选框, 同样需要筛选排序”

程序猿: “Fxxx”

那么这样的数据应该如何存储呢?

解决方案如下:

我们的value按照1,2,4,8…的二进制方式进行存储

用户选择单选框第一项, 则存1, 第二项则存2, 第三项则存4

用户选择多选框第一项+第三项:则存5, (1+4)

MongoDB为我们提供了强大的Aggregate功能, 其中包含了Bitwise Query Operators 功能, 包含$bitsAllSet ,$bitsAnySet , $bitsAllClear , $bitsAnyClear


db.items.aggregate([
{
“$match”: {
“$elemMatch”: {
“描述id”: “id”,
“value”: { $bitsAnySet: [ 1, 5 ] }
}
}}
])

以上完成了使用MongoDB动态字段设计的各种需求 😊

总结

  • 增加配置collection, 用来描述用户的配置
  • 原始值需要存储空值
  • 如需类似下拉框, 多选框时, 使用Bitwise Query Operators 来完成
  • MongoDB并没有那么弱, 也是可以满足复杂的数据需求的

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


联系我们
返回顶部