• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MongoDB进阶篇之动态字段设计

mysql 搞代码 4年前 (2022-01-09) 20次浏览 已收录 0个评论

这篇文章主要给大家介绍了MongoDB进阶之动态字段设计的相关资料,文中介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面跟着小编一起来学习学习吧。

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

适宜读者人群

  • MongoDB开发者

基础需求

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

技术目标version 1

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

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

普通字段索引

// 假如我们的文档长这样{ "name": "MongoDB", "age": 5}// 对age字段建立索引{ "age": 1}

内嵌文档索引

// 假如我们的文档长成了Object{ "person": {  "age": 2,  "name": "MongoDB" }}//对person.age字段建立索引{ "person.age": 1}

数组文档索引

// 假如我们的文档长成了数组{ "persons": [  { "name": "MongoDB", age: 5},  { "name": "MySQL", age: 20} ]}//对persons.age字段建立索引{ "persons.age": 1}

看似上面只有都无法做到动态增加字段的功能

程序员A和程序员S发生如下对话:

  • 程序猿A: "那么我们需要增加另外一个collection来存储动态的内容"

  • 程序猿S: "但MongoDB对关联查询的支持很弱啊, 都没法关联排序, 要是后面产品说要加 排序筛选 的功能我们就懵逼了呀☹️ , 唉~ 早知如此就不用MongoDB了"

再重新审视需求

  • 存储动态表单数据

  • 需要支持筛选和排序

技术目标version2

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

解决方案

  • 使用数组来存储动态字段

  • 增加描述collection用来记录用户的表单配置

存储结构如下:

//描述collection { "_id":"描述id", "type":"类型", "text": "订单名称", "default": "Default Name",}// 原本的表单增加字段form用来存储动态数据<div style="color:transparent">本文来源gaodai.ma#com搞##代!^码网(</div>{ "_id": "", "name": "一个好名字", "form":[ { "_id":"描述_id", "value": 10}, { "_id":"描述_id", "value": "我的好伙伴"}, ]}

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

如何查询排序筛选呢

// 比如用户增加了2个字段// 现在要对字段1进行排序db.items.find().sort({"form.0.value":1})// 对字段2进行筛选db.items.find({"form.1.value":"我的好伙伴"})

上面的例子可以看出, 即使用户未填写该字段值, 但我们依旧需要为它进行存储空值, 以保证我们所有的Document的form下第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动态字段设计的各种需求

以上就是MongoDB进阶篇之动态字段设计的详细内容,更多请关注搞代码gaodaima其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MongoDB进阶篇之动态字段设计

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址