MongoD动态添加字段怎样实现,用到哪些知识点
Admin 2022-11-16 群英技术资讯 1054 次浏览
今天这篇我们来学习和了解“MongoD动态添加字段怎样实现,用到哪些知识点”,下文的讲解详细,步骤过程清晰,对大家进一步学习和理解“MongoD动态添加字段怎样实现,用到哪些知识点”有一定的帮助。有这方面学习需要的朋友就继续往下看吧!适宜读者人群
基础需求
产品: "我们要为现有的表单增加一个伟大的功能, 允许用户增加想要的字段"
技术目标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动态字段设计的各种需求
总结
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了MongoDB的下载、安装与部署方法,需要的朋友可以参考下
这篇文章带大家深入了解MongoDB复制集原理,文本有详细的介绍以及示例,对于MongoDB复制集不是很清楚的朋友可以参考参考,接下来我们就一起来看看MongoDB复制集原理。
MongoDB 查询文档 MongoDB 查询文档使用 find() 方法。 find() 方法以非结构化的方式来显示所有文档。 语法 MongoDB 查询数据的语法格式如下: db.collection.find(query, projection) query :可选,使用查询操作符指定查询条件 projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)。 如果你需要以易读..
MongoDB 分片 分片 在Mongodb里面存在另一种集群,就是分片技术,可以满足MongoDB数据量大量增长的需求。 当MongoDB存储海量的数据时,一台机器可能不足以存储数据,也可能不足以提供可接受的读写吞吐量。这时,我们就可以通过在多台机器上分割数据,使得数据库系统能存储和处理更多的数据。 为什么使用分片 复制所有的写入操作到主节点 延迟的敏感数据会在主节点查询 单个副本集限制在12个节点 当请求量巨大时会出现内存不..
你是否了解过MongoDB数据库中的游标,爱站技术频道小编在这里来给朋友们说说这方面的相关资料,相信你读完这篇文章后会有很大的收获,下面就一起来看一看。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008