怎么新建MySQL数据库

发布时间:2021-11-24 作者:admin
阅读:897

    这篇文章我们来了解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动态字段设计的相关内容就介绍到这,希望大家阅读完这篇文章能有所收获。最后,想要了解更多MongoDB的内容,大家可以关注其它的相关文章。

文本转载自脚本之家

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145