本文主要介绍的是关于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发生如下对话:
再重新审视需求
技术目标version2
增加字段同时还要可以索引
解决方案
存储结构如下:
//描述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
# 动态字段
# mongodb动态添加字段
# 字段类型
# MySQL和MongoDB设计实例对比分析
# MongoDB 数据库的命名、设计规范详解
# windows7下使用MongoDB实现仓储设计
# MongoDB实现问卷/考试设计功能
# MongoDB设计方法以及技巧示例详解
# 表单
# 文档
# 成了
# 多选
# 的是
# 第三项
# 下拉框
# 好了
# 均为
# 朋友们
# 第一项
# 几种
# 就可
# 说要
# 相关资料
# 要对
# 可以看出
# 另外一个
# 这篇文章
# 谢谢大家
相关文章:
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
,想在网上投简历,哪几个网站比较好?
大型企业网站制作流程,做网站需要注册公司吗?
建站主机默认首页配置指南:核心功能与访问路径优化
已有域名和空间如何搭建网站?
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
c# 在高并发场景下,委托和接口调用的性能对比
如何快速搭建二级域名独立网站?
网站设计制作公司地址,网站建设比较好的公司都有哪些?
黑客如何通过漏洞一步步攻陷网站服务器?
网站代码制作软件有哪些,如何生成自己网站的代码?
如何制作算命网站,怎么注册算命网站?
一键制作网站软件下载安装,一键自动采集网页文档制作步骤?
建站之星与建站宝盒如何选择最佳方案?
建站之星安装后如何自定义网站颜色与字体?
建站主机数据库如何配置才能提升网站性能?
建站之星后台密码遗忘?如何快速找回?
建站之星在线客服如何快速接入解答?
建站之星安装后如何配置SEO及设计样式?
高端智能建站公司优选:品牌定制与SEO优化一站式服务
岳西云建站教程与模板下载_一站式快速建站系统操作指南
北京的网站制作公司有哪些,哪个视频网站最好?
如何零成本快速生成个人自助网站?
南京做网站制作公司,南京哈发网络有限公司,公司怎么样,做网页美工DIV+CSS待遇怎么样?
如何用PHP快速搭建CMS系统?
再谈Python中的字符串与字符编码(推荐)
免费制作统计图的网站有哪些,如何看待现如今年轻人买房难的情况?
如何在阿里云通过域名搭建网站?
淘宝制作网站有哪些,淘宝网官网主页?
如何在新浪SAE免费搭建个人博客?
如何高效生成建站之星成品网站源码?
如何高效利用亚马逊云主机搭建企业网站?
Python如何创建带属性的XML节点
如何选择PHP开源工具快速搭建网站?
小型网站建站如何选择虚拟主机?
洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
如何彻底删除建站之星生成的Banner?
如何基于云服务器快速搭建个人网站?
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
利用JavaScript实现拖拽改变元素大小
如何在云主机快速搭建网站站点?
个人网站制作流程图片大全,个人网站如何注销?
建站上市公司网站建设方案与SEO优化服务定制指南
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
如何通过虚拟机搭建网站?详细步骤解析
如何用腾讯建站主机快速创建免费网站?
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
山东网站制作公司有哪些,山东大源集团官网?
*请认真填写需求信息,我们会在24小时内与您取得联系。