MongoDB学习笔记_3_文档

Wesley13
• 阅读 857

文档

基础概念

  • MongoDB的文档等同于SQL的记录
  • 在mongodb中数据的组建形式
  • 由键值组成
  • mongodb中数据文档为bson格式

文档中键的命名规则

  1. utf-8格式的字符串
  2. 不能由'\0',不能为空
  3. 以_开头的很多事保留的键,,所以一般不用_开头
  • 注意
    1. 文档中的键值对是有序的
    2. 文档中的值指的就是文档支持的数据类型
    3. mongodb中区分大小写

支持类型

类型

注释

整型

整数,32位整型

布尔

True,False

浮点型

存储小数

Arrays

列表数组

Timestamp

时间戳

Date

时间日期

Object

内部文档

Null

空值

Symbol

特殊字符串

Binary data

二进制数据

code

代码

regax

正则表达式

ObjectId

ObjectId字符串

集合设计原则

  1. 同一类文档存在一个集合中
  2. 集合中尽量存储域和文档格式相近的文档
  3. 集合中可以存在文档数据的差异

插入文档

  • 单文档插入
    • db.collection_name.insert()
  • 插入多条文档
    • db.collection_name.insert([{},{}])
  • save插入数据
    • db.collection_name.save()
      • 如果不添加_id域的时候,同insert
      • 如果添加_id域,该域值如果不存在则会添加,若存在会修改原有数据
      • save不能够插入多条文档

查找

  • find()
    • db.collection_name.find()-->select * from tableName
    • 功能:查找所有符合筛选要求的文档
    • 参数:
      • query:筛选条件 相当于where子句

        1. 以键值对的方式确定查找条件。
        2. 如果不写这个参数则表示查找所有文档。
      • field:展示的域

        1. 以键值对的形式给每个域赋值表示是否要显示该域。
          • 0 表示 不展示该域
          • 1 表示 展示该域
        2. 如果给域设置为0,则其它域自动为1,如果给某个域设置为1,其他自动为0,两者不能混用。
        3. _id比较特殊,默认为1,如果不想显示则设置为0。_id为0时,其他值是可以为1的。
        4. 如果不写该参数,则表示全部显示。
    • 返回值:返回所有的符合要求的文档
    • e.g. db.class.find({age:22},{_id:0,name:1})
  • findOne
    • db.collection_name.findOne()
    • 功能:查找符合条件的第一条文档
    • 参数:同find
    • 返回值:返回查找到的文档

删除文档

  • remove()
    • db.collection_name.remove(query,justOne)
    • 功能:删除文档
    • 参数:
      • query:同find
      • justOne:bool值,是否删除第一条匹配到的文档,默认false。

更新文档

  • update()
    • db.collection_name.update(query,update,upsert,multi)
    • 功能:更新一个文档数据
    • 参数:
      • query:定位要更新的数据,与find用法相同
      • update: 将数据更新为什么,相当于set,需要配合修改器操作符来使用
      • upsert: bool值,默认false,表示当定位的文档不存在则无法修改。如果设置为true,表示如果定位的文档不存在则插入这条文档。
      • multi:bool值,默认为false,如果query匹配的文档有多条只修改第一条。如果设置为true,则修改所有匹配到的文档。
      • e.g.: db.class.update({name:'a'},{$set{age:19}})
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
5个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
MongoDB介绍
MongoDB介绍制作人:全心全意MongoDB存储的是json对象(文档型存储)。MongoDB将磁盘格式化为gridfs,在此文件格式上存储数据,存储的数据为二进制的json格式。MongoDB引用了chrome独特的js引擎chromev8,所以MongoDB有能力执行JS。命令介绍
Wesley13 Wesley13
3年前
MongoDB数据库操作
MongoDB是一个面向文档的数据库系统.使用c编写,不支持sql.但有自己功能强大的查询语法.MongoDB使用BSON作为数据存储和传输的格式,BSON是一种类似JSON的二进制序列化文档,支持嵌套对象和数组.MongoDB很像mysql,document对应mysql的row,collection对应mysql的table应用场景:
Wesley13 Wesley13
3年前
MongoDB 基本使用
MongoDB是一个基于分布式文件存储的数据库。由C语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。MongoDB将数据存储为一个文档,数据结构由键值(keyvalue)对组成。MongoDB文档(
Stella981 Stella981
3年前
MongoDB 文档(Document)操作
MongoDB文档操作(增、删、改)在MongoDB中文档是指多个键及其关联的值有序地放置在一起就是文档,其实指的就是数据,也是我们平时操作最多的部分MongoDB中的文档的数据结构和JSON基本一样。所有存储在集合中的数据都是BSON格式BSON是一种类似JSON的二进制形式的存储格式,是
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
11个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这