首页 数据库 mysql教程 MongoDB进阶篇之动态字段设计

MongoDB进阶篇之动态字段设计

May 17, 2018 pm 02:00 PM
mongodb 字段 设计

这篇文章主要给大家介绍了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用来存储动态数据
{
 "_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进阶篇之动态字段设计的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它们
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

荣耀Magic V3首发AI离焦护眼技术:有效缓解近视发展 荣耀Magic V3首发AI离焦护眼技术:有效缓解近视发展 Jul 18, 2024 am 09:27 AM

7月12日消息,荣耀MagicV3系列今日正式发布,搭载全新荣耀视力舒缓绿洲护眼屏,在屏幕本身具备高规格和高素质的同时,还开创性的引入AI主动式护眼技术。据悉,传统的缓解近视的方式是“近视镜”,近视眼镜度数均匀分布,保证了视线中心区域成像在视网膜之上,但周边区域成像在视网膜后,视网膜感应到成像在后,促进眼轴向后生长,从而使度数加深。目前主要的缓解近视发展的方式之一是“离焦镜”,其中心区域度数正常,周边区域通过光学设计分区调整,从而使周边区域成像落在视网膜前,

1399元起 荣耀X60i手机开售:视觉四等边OLED直屏 1399元起 荣耀X60i手机开售:视觉四等边OLED直屏 Jul 29, 2024 pm 08:25 PM

7月29日消息,荣耀X60i手机今日正式开售,首发1399元。设计上,荣耀X60i手机采用居中挖孔直屏设计,四边近乎无界的超窄边框,极大地拓宽了视野边界。荣耀X60i参数显示屏:6.7英寸高清显示屏电池:5000mAh大容量电池处理器:天玑6080处理器(台积电6nm,2x2.4G的A76+6×2G的A55)系统:MagicOS8.0系统其他功能:5G信号增强灵动胶囊屏下指纹双MIC降噪知识问答摄影能力:后置双摄系统:5000万像素主摄200万像素辅助镜头前置自拍镜头:800万像素价格:8GB

全新堆叠工艺!小米MIX Fold 4首搭金沙江'立体异形”电池 全新堆叠工艺!小米MIX Fold 4首搭金沙江'立体异形”电池 Jul 20, 2024 am 03:20 AM

7月19日消息,小米MIXFold4首旗舰折叠新机今晚正式发布,首次搭载“立体异形电池”。据介绍,小米MIXFold4在电池技术上实现了重大突破,专为折叠屏设计了创新的“立体异形电池”。传统折叠屏设备多采用常规方形电池,空间利用效率较低。为解决这一问题,小米没有采用常见的卷绕式电芯,而是全新开发叠片工艺,打造全新形态的电池,大幅提升了空间利用率。电池技术创新为了实现精确交替堆叠正负极片,确保锂离子安全嵌入,小米开发了新型超声焊接机和叠片机,提高了焊接和裁切精

小米百元机 Redmi 14C 设计规格曝光 将于 8 月 31 日发布 小米百元机 Redmi 14C 设计规格曝光 将于 8 月 31 日发布 Aug 23, 2024 pm 09:31 PM

小米的Redmi品牌正准备在其产品组合中增加另一款经济型手机——Redmi14C。该设备已确认将于8月31日在越南发布。然而,在发布之前,这款手机的规格已经通过越南零售商被披露。Redmi14CRedmi经常在新系列中带来全新的设计,Redmi14C也不例外。这款手机背面有一个大的圆形摄像头模块,与前代的设计完全不同。蓝色配色版甚至采用渐变设计,让它看起来感觉更加高端。不过,实际上Redmi14C是一款经济型手机。相机模组包括四个环;一个环内装有5000万像素主传感器,另一个可能装有用于深度信息

荣耀Magic V3成功挑战滚筒洗衣机15分钟快洗:折叠唯一通过2.5米防水认证 荣耀Magic V3成功挑战滚筒洗衣机15分钟快洗:折叠唯一通过2.5米防水认证 Jul 18, 2024 pm 01:58 PM

7月12日消息,荣耀MagicV3今日正式发布,将折叠屏手机厚度带入9.2毫米。尤为值得一提的是,荣耀MagicV3在追求极致轻薄的同时,更通过前沿科技的运用,实现了行业领先的防水性能。得益于其采用的10微米级精密填充技术,这款手机不仅达到了IPX8级别的防水标准,即便在湿润环境下也能保持触控灵敏,为用户带来无忧的使用体验。发布会现场,荣耀更是以一场大胆的实验,直接将MagicV3置于滚筒洗衣机中进行15分钟快洗测试,结果令人惊叹——手机不仅安然无恙,更彰显了其卓越的防水实力。荣耀

世界最小5G手机正式发布:5.05寸小屏 配1亿主摄 世界最小5G手机正式发布:5.05寸小屏 配1亿主摄 Jul 19, 2024 pm 09:10 PM

7月19日消息,据媒体报道,国外厂商UnihertzJellyMax推出了一款世界上最小的5G手机,售价为199美元。据悉,JellyMax在保持极致便携性的同时,搭载了5.05英寸的HD+LCD显示屏,采用挖孔设计,屏幕分辨率720x1520像素。值得注意的是,其重量约180克,相较于iPhone13mini的轻盈(140克)。硬件配置联发科天玑7300高性能处理器12GBLPDDR5x高速内存256GBUFS3.1海量存储Android14操作系统拍照系统100MP主摄像头8MP长焦镜头32

449元起 智云写趣CQ5智能手机云台发布:支持语音控制 449元起 智云写趣CQ5智能手机云台发布:支持语音控制 Jul 31, 2024 pm 10:37 PM

7月31日消息,智云今日推出了写趣CQ5智能手机云台,支持手机拍摄,且支持语音操控,标配版定价449元,跟拍版定价599元。写趣CQ5的一大亮点在于其内置的先进语音助手“小智”,它让拍摄操作变得前所未有的便捷。用户只需简单口令,即可实现横竖屏模式的无缝切换、即刻启动录制功能,甚至远程声控快门,让灵感捕捉不再受限于手动操作。更令人惊喜的是,其语音识别范围可达约3米,确保在多数拍摄场景下都能精准响应。1.写趣CQ5配备了可伸缩延长杆,灵活应对各种拍摄角度。可选配磁吸AI跟踪模块,智能识

小米MIX Fold 4首创全碳架构:抗冲击性能提升至300% 小米MIX Fold 4首创全碳架构:抗冲击性能提升至300% Jul 19, 2024 pm 09:47 PM

7月19日消息,小米MIXFold4今晚如期而至,轻至226g,单边薄至4.59mm,折叠薄至9.47mm。据介绍,小米MIXFold4首创全碳架构,超大碳纤维使用面积转轴浮板、屏幕衬板和中板电池仓全部采用T800H高强碳纤维材料,抗冲击强度提升300%。这种材料具有超高抗拉强度,达5500MPa,是6M42铝合金的13倍,普通铝合金的25倍。在相同力学性能需求下,重量仅为6M42铝合金的1/15。这一选择不仅大幅降低了设备重量,还显着提升了整体强度。 1.采用了先进的“单向带”工艺

See all articles