位置: 编程技术 - 正文

mongodb 数据类型(null/字符串/数字/日期/内嵌文档/数组等)(mongodb数据类型有哪些)

编辑:rootadmin

推荐整理分享mongodb 数据类型(null/字符串/数字/日期/内嵌文档/数组等)(mongodb数据类型有哪些),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongodb数据存储格式,mongodb 数据类型转换,mongodb 数据类型转换,mongodb 数据类型 Javascript,mongoDB数据类型,mongodb数据表,mongodb 数据类型 Javascript,mongodb 数据类型 Javascript,内容如对您有帮助,希望把文章链接给更多的朋友!

MongoDB的文档类似于JSON,JSON只是一种简单的表示数据的方式,只包含了6种数据类型(null、布尔、数字、字符串、数组及对象).

JSON的数据类型的局限性:1.无日期类型,对日期型的处理较为繁琐2.无法区分浮点数和整数、位和位3.其他类型表示局限 如函数、正则式等

Mongodb使用BSON(Binary JSON)来组织数据,BSON还提供日期、位数字、位数字等类型。下面为在mongodb shell中这些类型在文档中是如何表示:

1、null 用于表示空值或者不存在的字段。

{"name":null}

2.布尔 布尔类型、即true和false

{"flag":true}/{"flag":false}

3.数字 mongodb中分位整数、位整数、位浮点数

>JavaScript只支持位浮点数,shell中对位的整数会进行自动的转换: 默认情况下,shell中的数字被mongdb当做是双精度。若从数据库中获取一个位整数,修改了文档后在将文档保存到数据库的时候,这个整数已被转换成了浮点数(整数不变也会转换)。 >shell中会用内嵌文档的方式显示位整数: 数字智能表示为双精度数(位浮点数)的另一个问题是,有些位的整数并不能精确的表示位浮点数。因此要是存入了一个位整数然后在shell中查看,它显示一个内嵌的文档,表示可能不准确。 如: 插入文档{"name":"apple","num":5},其中"num"设置为位整数5. 查看如下: { "_id" : ObjectId("f7afeada"), "name" : "apple", "num" : {"floatApprox" : 5} } 插入文档{"name":"orange","num":} 查看如下: { "_id" : ObjectId("f7afeada"), "name" : "apple", "num" : {"floatApprox" : ,"top" : , "bottom" : } } 以上实例(可自己尝试见证)文档参见:Mongodb权威指南 我在本机(win7 位)插入如下文档: {"name":"apple","num":5} {"name":"orange","num":} {"name":"peach","num":} >db.a.find() { "_id" : ObjectId("f7afeada"), "name" : "apple", "num" : 5 } { "_id" : ObjectId("feada"), "name" : "orange", "num" : } { "_id" : ObjectId("fbdeada"), "name" : "peach", "num" : 9.e+ } 位浮点数: {"num":3.}/{"num":3} 4.字符串 UTF-8字符串都可以表示为字符串类型的数据

{"name":"orange"}

5.符号 shell中不支持,并将数据库里的符号类型都转换成字符串

6.对象id是文档的字节的唯一ID

{"x":Object()} Mongodb中存储的(同一个集合内)文档必须有,只有唯一的“_id”键。值可为任意类型,必须保证其唯一性,默认为ObjectId对象。至于mongodb为什么用ObjectId对象,以及它有什么好处等请翻阅相关资料。

mongodb 数据类型(null/字符串/数字/日期/内嵌文档/数组等)(mongodb数据类型有哪些)

下面是ObjectId的构成: ObjectId使用字节的存储空间,每个字节两位十六进制数字,是一个位的字符串。字节按照如下方式生成: 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | | 时间戳 | 机器码 | PID | 计数器 ----------------------------------------------- >时间戳:从标准的纪元开始的时间戳,单位为秒。 >机器码:所在主机的唯一标示符,通常为机器主机名的散列值。 >PID:产生ObjectId的进程标示符。 >计数器:自动增加计数器,同一秒最多允许每个进程拥有的3次方()个不同的ObjectId。 文档的"_id"键: 1.插入文档的时候,没有该键,系统自动创建一个。 2.mongodb服务器可自动创建,通常在客户端由驱动程序完成: >减少数据库扩展的负担 >驱动程序提供丰富的API,可返回ObjectId,也可插入文档;若有服务器生成的话,驱动程序需单独的查询来确定插入的文档中的"_id"值。 7.日期型 存储的是从标准纪元开始的毫秒数,不存储时区。

{"name":"xx","date":new Date()} 本机查看:{ "_id" : ObjectId("eada"), "name" : "xx", "date" : ISODate("--T::.Z") }

8.正则式 文档中可以包含正则表达式,采用javascript的正则表达式语法

{"regex":/[0-9]/g}

9.代码或者函数 javascript代码(mongodb中值直接保存到数据库,不对值进行执行,因此不存在安全问题)

{"setName":function(){var name="jk";alert(name)}} .二进制数 可以由任意字节的串组成。shell中无法使用。

.最大值 BSON包括一个特殊类型,表示可能的最大值。shell没有这个类型。

.最小值 BSON包括一个特殊类型,表示可能的最小值。shell没有这个类型。

.未定义(undefined) 文档中也可以使用未定义类型

{"name":undefined}

.数组 值的集合或者列表可以表示成数组

{"name":["s","d","f"]}

.内嵌文档 文档可以包含文档,作为值嵌入到父文档中

{"sch" : "s" "catl" : { "c1" : {"cls1" : "cs1","cls2" : "cs2","cls3" : "cs3"} "c2" : {"cls1" : "cs1","cls2" : "cs2","cls3" : "cs3"} "c3" : {"cls1" : "cs1","cls2" : "cs2","cls3" : "cs3"} }}

从面向对象的角度来理解文档,文档就是个对象,文档里面的key/value就是属性和属性值。

MongoDB的创建、更新和删除 概要下面开始学习MongoDB最重要也是最基础的部分:C(创建)R(查询)U(更新)D(删除);由于R(查询)操作相对来说内容比较多,也比较繁琐,同

MongoDB的下载、安装与部署方法 1、什么是MongoDB?它是介于关系型数据库和非关系型数据库之间的一种NoSQL数据库,用C++编写,是一款集敏捷性、可伸缩性、扩展性于一身的高性能的面

MongoDB的基础知识简介 1、文档、集合和数据库a)、文档:因为MongoDB是面向文档的数据库,那么可想而知文档是它的基本单元,相当于关系型数据库中的行!Ⅰ、它是由键值

标签: mongodb数据类型有哪些

本文链接地址:https://www.jiuchutong.com/biancheng/312629.html 转载请保留说明!

上一篇:mongodb 修改器($inc/$set/$unset/$push/$pop/upsert)(mongodb如何修改数据)

下一篇:MongoDB的创建、更新和删除(mongodb createindex)

  • 工资薪金和工资薪金总额区别
  • 车辆报废做账务处理依据的法规是
  • 附加税减半征收的条件
  • 别人公司过账用自己的银行卡会查吗
  • 驾驶员行车补贴开什么发票
  • 代发工资记什么科目
  • 企业职工遣散费标准
  • 会务费账务处理
  • 技术研发支出会计科目
  • 收到销售折让的红字怎么做账
  • 库存商品变价出现原因
  • 计提利息怎么做账
  • 小规模纳税人附加税税率各是多少
  • 税务迁移会影响外经证核销吗
  • 农产品没有进项税怎么算
  • 职工发放洗漱用品怎么进行财税处理?
  • 中国公司可以给境外公司开发票吗
  • 在建工程完工,并当日签订出租协议的会计分录
  • 财政收据可以抵税吗
  • 暂估入库库存出现负数怎么办?
  • 公司租赁个人车辆需要哪些手续
  • 电脑黑屏怎么办主机还是亮的
  • u盘的内存卡怎么装
  • 怎样升级智慧中小学版本软件
  • 临时设施是租入还是租入
  • 公司银行贷款能贷多少
  • win11自带的播放器
  • 支付广告费会计怎么做账
  • 高德地图api获取当前经纬度的城市地图
  • 贷款和应收款项应采用实际利率法,按摊余成本计量
  • 固定资产一次性扣除申报表怎么填
  • php文字转语音源码
  • 【2023-Pytorch-检测教程】手把手教你使用YOLOV5做电线绝缘子缺陷检测
  • 爱德华多·阿涅利
  • 固定资产维修费计入固定资产吗
  • 存货跌价准备的转销会计分录
  • php实现截取中文字符
  • maven安装成功命令
  • 审计招标费包含哪些内容
  • 购买金税盘的费用会计分录
  • 计提工会经费怎么做账务处理
  • 预缴增值税所需成本
  • phpcms 标签
  • 织梦可以放两套模板吗
  • pandas columns排序
  • 工人意外伤害保险
  • 收到报销单如何处理
  • 视同小规模纳税人是有?
  • 红冲的发票能不能取消
  • 一次性开票分期收入账务处理
  • 储值卡金额算什么资产
  • 土地增值税清算收入如何确定
  • 建筑企业的安全技术措施
  • 预付账款转入其他应付款会计分录
  • 税票名称开错了有影响么
  • 跨国公司国内外发展现状
  • win8系统的运行在哪里打开
  • w10 2021年更新
  • win8网络设置
  • win10系统内置应用软件有哪些
  • win10系统中怎么重新启动netframework
  • JavaScript的instanceof运算符学习教程
  • cocos code ide 1.0.0 RC0 使用教程
  • cocos2dx4.0教程
  • 安卓开发过程中的问题
  • 修改系统用户名为英文
  • 文件夹权限命令
  • 批处理打开网络连接
  • 安卓模拟器错误怎么办
  • 用python模拟用户登录
  • 用javascript
  • JavaScript While 循环 教程
  • 安卓9api
  • js 对象key
  • 网上怎么申报地税
  • 浙江网上税务局app下载
  • 黑龙江省国税局网站
  • 土地增值税的房屋转让指出售 赠与
  • 朝阳区地方税务局电话
  • 船员工资是否需交税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设