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中文网其他相关文章!

热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

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

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

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

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

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

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

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

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