mongodb保存数据时,字段名带点号时保存会以子文档的形式保存

2024-08-27 16:32

本文主要是介绍mongodb保存数据时,字段名带点号时保存会以子文档的形式保存,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

例子

我要保存这样的数据:

{ "date" : { "$date" : "2016-10-09T16:00:00.000Z"} , 
"createtime" : { "$date" : "2016-12-27T09:36:13.305Z"} , 
"status" : 1 , "registry_sum" : 114 , 
"Go-Goal新一代V3.0" : 2 , 
"Go-Goal新一代V3.0_mobile" :  null  , 
"Go-Goal新一代V3.0_email" : 2 , 
"Go-Goal新一代V3.0_weixin" :  null  , 
"Go-Goal新一代V3.0_mobile_success" :  null  , 
"Go-Goal新一代V3.0_mobile_fail" :  null  , 
"Go-Goal新一代V3.0_email_success" :  null  , 
"Go-Goal新一代V3.0_email_fail" : 2 , 
"Go-Goal新一代V3.0_weixin_success" :  null  , 
"Go-Goal新一代V3.0_weixin_fail" :  null  , 
"Go-Goal新一代V3.0_mobile_success_person" :  null  , 
"Go-Goal新一代V3.0_mobile_fail_person" :  null  , 
"Go-Goal新一代V3.0_mobile_success_business" :  null  , 
"Go-Goal新一代V3.0_mobile_fail_business" :  null  , 
"Go-Goal新一代V3.0_email_success_person" :  null  , 
"Go-Goal新一代V3.0_email_fail_person" : 2 , 
"Go-Goal新一代V3.0_email_success_business" :  null  , 
"Go-Goal新一代V3.0_email_fail_business" :  null  , 
"Go-Goal新一代V3.0_weixin_success_person" :  null  , 
"Go-Goal新一代V3.0_weixin_fail_person" :  null  , 
"Go-Goal新一代V3.0_weixin_success_business" :  null  , 
"Go-Goal新一代V3.0_weixin_fail_business" :  null 
}

我们可以看到保存的字段例如:Go-Goal新一代V3.0是带有点号的。

但是保存到mongodb中就变成了子文档的显示:

    "Go-Goal新一代V3" : {"0" : 2,"0_email" : 2,"0_email_fail" : 2,"0_email_fail_business" : null,"0_email_fail_person" : 2,"0_email_success" : null,"0_email_success_business" : null,"0_email_success_person" : null,"0_mobile" : null,"0_mobile_fail" : null,"0_mobile_fail_business" : null,"0_mobile_fail_person" : null,"0_mobile_success" : null,"0_mobile_success_business" : null,"0_mobile_success_person" : null,"0_weixin" : null,"0_weixin_fail" : null,"0_weixin_fail_business" : null,"0_weixin_fail_person" : null,"0_weixin_success" : null,"0_weixin_success_business" : null,"0_weixin_success_person" : null},

这里写图片描述

我们可以看到,它变成了,字段为Go-Goal新一代V3value变成了子文档的形式。

那么我们该怎么访问呢?

访问子文档

db.gg_registry.find({"Go-Goal新一代V3.0":5, "Go-Goal新一代V3.0_email":2})

也就是说,访问子文档,就是字段加.号就可以了,这与我想保存字段为Go-Goal新一代V3.0是不冲突的。

结果为:

    "Go-Goal新一代V3" : {"0" : 5,"0_email" : 2,"0_email_fail" : 2,"0_email_fail_business" : 1,"0_email_fail_person" : 1,"0_email_success" : null,"0_email_success_business" : null,"0_email_success_person" : null,"0_mobile" : 1,"0_mobile_fail" : 1,"0_mobile_fail_business" : null,"0_mobile_fail_person" : 1,"0_mobile_success" : null,"0_mobile_success_business" : null,"0_mobile_success_person" : null,"0_weixin" : 2,"0_weixin_fail" : 2,"0_weixin_fail_business" : null,"0_weixin_fail_person" : 2,"0_weixin_success" : null,"0_weixin_success_business" : null,"0_weixin_success_person" : null},

官网文档 Query查询

这篇关于mongodb保存数据时,字段名带点号时保存会以子文档的形式保存的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112192

相关文章

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L

使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)

《使用Python和Matplotlib实现可视化字体轮廓(从路径数据到矢量图形)》字体设计和矢量图形处理是编程中一个有趣且实用的领域,通过Python的matplotlib库,我们可以轻松将字体轮廓... 目录背景知识字体轮廓的表示实现步骤1. 安装依赖库2. 准备数据3. 解析路径指令4. 绘制图形关键