文档是 MongoDB 的核心,类似于 SQLite 数据库(关系数据库)中的每一行数据。多个键及其关联的值放在一起就是文档。在 Mongodb 中使用一种类 json 的 bson 存储数据,bson 数据可以理解为在 json 的基础上添加了一些 json 中没有的数据类型。
    例:
        {"company":"Chenshi keji"}
        
元数据
    数据库的信息存储在集合中,他们统一使用系统的命名空间:DBNAME.system.* DBNAME 可用 db 或数据库名替代
        DBNAME.system.namespaces :列出所有名字空间
        DBNAME.system.indexs :列出所有索引
        DBNAME.system.profile :列出数据库概要信息
        DBNAME.system.users :列出访问数据库的用户
        DBNAME.system.sources :列出服务器信息

创建数据库
    范例:进入 MongoDB 命令行操作界面之后,进行如下操作:
        > use Chenshi
        switched to db Chenshi
    
    您可以使用 db 命令查看您当前选择的数据库
        > db
        Chenshi

    您也可以通过使用 show dbs 命令查看所有的数据库
        > show dbs

    在这条命令之后您刚才创建的 Chenshi 不会显示,这只有在向数据库中插入了数据之后才能显示

删除数据库
    语法:db.dropDatabase()
    假设刚才我们使用语句 db.computer.insert({"name":"killer"}) 对数据库 Chenshi 进行了数据插入操作
        > show dbs      #显示当前系统中的所有数据库
        > use Chenshi   #转到Chenshi数据库
        switched to db Chenshi
        > db.dropDatabase()
        {"dropped":"Chenshi","ok":1}
        > show dbs

集合
    集合就是一组文档的组合,就相当于是关系数据库中的表,在 MongoDB 中可以存储不同的文档结构的文档。 例:
        {"company":"Chenshi keji"} {"people":"man","name":"peter"}    
        
    创建集合
        语法:
            db.createCollection(name,options)
        参数描述:
            name:创建的集合名称
            options:是一个作为初始化的文档(可选)
        范例:
            > db.createCollection("killer")            #无参数
            { "ok" : 1 }
            > show collections
            killer
            system.indexes
            > db.createCollection("killer2", { capped : 1, autoIndexID : 1, size : 6142800, max : 10000 } )            #带参数
            { "ok ": 1 }
        参数描述:
            capped:类型为 Boolean,如果为 true 则创建一个固定大小的集合,当其条目达到最大时可以自动覆盖以前的条目。在设置其为 true 时也要指定参数大小;
            autoIndexID:类型为 Boolean,默认为 false,如果设置为 true,则会在 _id field.s 上自动创建索引;
            size:如果 capped 为 true 需要指定,指定参数的最大值,单位为 byte;
            max:指定最大的文档数。 在 Mongodb 中也可以不用创建集合,因为在创建文档的时候也会自动的创建集合。

    删除集合
        语法:db.COLLECTION.drop()
        操作实例:
            > use Chenshi
            switched to db Chenshi
            > show collections
            killer
            killer2
            system.indexes
            > db.killer.drop()
            true
            > show collections
            killer2
            system.indexes
        删除成功
        --注意:当您要删除指定的集合时,用您想要删除的集合名称替代 COLLECTION 即可

    插入文档
        语法:db.COLLECTION_NAME.insert(document)
        操作实例:
            > userdoc1=({"user_id":1,"name":"cloud","state":"active","actor":"user","e-mail":"test@qq.com","VM_num":2,"time":[{"date":"2014-08-12","hour":"10:53 PM"}] })        
            > userdoc2=({"user_id":2,"name":"testadmin","state":"active","actor":"admin","e-mail":"test@qq.com","VM_num":2,"time":[{"date":"2014-08-11","hour":"06:34 AM"}] })    
            > doc1=({"name":"peter","position":"teacher"})        #先定义文档
            > use Chenshi
            switched to db Chenshi
            > db.killer.insert(userdoc1)
            WriteResult({"nInserted":1})
            > db.killer.insert(userdoc2)
            WriteResult({"nInserted":1})
            > db.killer.insert(doc1)
            WriteResult({"nInserted":1})
        插入文档成功,当然也可以直接将文档的内容作为函数的参数直接替代 document。
        
        语法:save()
            > db.users.save([
            ... { name : "jam",
            ... email : "jam@qq.com"
            ... },
            ... { name : "tom",
            ... email : "tom@qq.com"
            ... }
            ... ])

更新文档
    语法:db.COLLECTION_NAME.update(SELECTION_CRITERIA,UPDATED_DATA)
    操作实例:
        > db.killer.update({"user_id":2,"e-mail":"test@qq.com"},{$set:{"e-mail":"group@qq.com"}})
        WriteResult({"nMatched":1,"nUpserted":1,"nModified":1})
        > db.killer.find()
        
        将 user_id=2 的文档的 e-mail 改为 group@qq.com
        第一个大括号内容标示查找条件,第二个大括号内容则表示更新后的数据
        默认的 update 函数只对一个文档更新,如果想作用所有文档,则需要加入 multi:true
    操作实例:
        db.killer.update({"e-mail":"test@qq.com"},{$set:{"e-mail":"group@qq.com"}},{multi:true})

替换已存在的文档
    语法:db.COLLECTION_NAME.save({_id:ObjectId(),NEW_DATA})
    操作实例:
        >db.shiyanlou.save({"_id":ObjectId("53ea174ccb4c62646d9544f4"),"name":"Bob","position":"techer"})
        WriteResult({"nMatched":1,"nUpserted":1,"nModified":1})
    这里的 _id 对应的是要替换文档的 _id。
    跟 insert 差不多,但是 update 更好用。

删除文档
    语法:db.COLLECTION_NAME.remove(DELECTION_CRITERIA)
    操作实例:
        > db.shiyanlou.remove({"name":"Bob"})
        WriteResult({"nRemoved":1})
    其实 remove 函数的参数跟 update 函数的第一个参数一样,相当于查找条件,注意,不要误删!
    删除后可以用查找命令确认数据:
        > db.killer.find()
        
        
createCollection():创建集合

db.COLLECTION.drop():删除集合

db.COLLECTION_NAME.insert(document):插入文档

db.COLLECTION_NAME.update(SELECTION_CRITERIA,UPDATED_DATA):更新文档

db.COLLECTION_NAME.save({_id:ObjectId(),NEW_DATA}):替换已存在的文档

db.COLLECTION_NAME.remove(DELECTION_CRITERIA):删除文档

mongodb(一)的更多相关文章

  1. 【翻译】MongoDB指南/聚合——聚合管道

    [原文地址]https://docs.mongodb.com/manual/ 聚合 聚合操作处理数据记录并返回计算后的结果.聚合操作将多个文档分组,并能对已分组的数据执行一系列操作而返回单一结果.Mo ...

  2. 【翻译】MongoDB指南/CRUD操作(四)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(四) 1 查询方案(Query Plans) MongoDB 查询优化程序处理查询并且针对给定可利用的索引选 ...

  3. 【翻译】MongoDB指南/CRUD操作(三)

    [原文地址]https://docs.mongodb.com/manual/ CRUD操作(三) 主要内容: 原子性和事务(Atomicity and Transactions),读隔离.一致性和新近 ...

  4. 【翻译】MongoDB指南/CRUD操作(二)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(二) 主要内容: 更新文档,删除文档,批量写操作,SQL与MongoDB映射图,读隔离(读关 ...

  5. 【翻译】MongoDB指南/CRUD操作(一)

    [原文地址]https://docs.mongodb.com/manual/ MongoDB CRUD操作(一) 主要内容:CRUD操作简介,插入文档,查询文档. CRUD操作包括创建.读取.更新和删 ...

  6. CRL快速开发框架系列教程十二(MongoDB支持)

    本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...

  7. MongoDB系列(二):C#应用

    前言 上一篇文章<MongoDB系列(一):简介及安装>已经介绍了MongoDB以及其在window环境下的安装,这篇文章主要讲讲如何用C#来与MongoDB进行通讯.再次强调一下,我使用 ...

  8. MongoDB系列(一):简介及安装

    什么是MongoDB MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统. 在高负载的情况下,添加更多的节点,可以保证服务器性能. MongoDB 旨在为应用提供可扩展的高 ...

  9. [原]分享一下我和MongoDB与Redis那些事

    缘起:来自于我在近期一个项目上遇到的问题,在Segmentfault上发表了提问 知识背景: 对不是很熟悉MongoDB和Redis的同学做一下介绍. 1.MongoDB数组查询:MongoDB自带L ...

  10. 用MongoDB分析合肥餐饮业

    看了<从数据角度解析福州美食>后难免心痒,动了要分析合肥餐饮业的念头,因此特地写了Node.js爬虫爬取了合肥的大众点评数据.分析数据库我并没有采用MySQL而是用的MongoDB,是因为 ...

随机推荐

  1. 解决 Asp.Net5 在视频文件下载预览时无法快进的问题

    前情提要 https://www.cnblogs.com/puzhiwei/p/15265005.html 在解决.Net5 如何修改Content-Disposition实现在线预览的功能后,我又遇 ...

  2. Linux环境下安装java的方法

    linux安装java步骤 方式一:yum方式下载安装 1.查找java相关的列表 yum -y list java* 或者 yum search jdk 2.安装jdk yum install ja ...

  3. 2020.10.9--vj个人赛补题

    B - A Tide of Riverscape 题意:给出一组字符串,由'0','1',' . '组成,' . '可以换成 0或1,判断第 i  个和第 i+p 个字符是否可以不相等,如果可以则输出 ...

  4. 全场景效能平台猪齿鱼常用的前端css实现方案

    ​ 居中 最常用的height + line-height,以及margin:0 auto的居中方式就不再阐述,以下介绍两种容错性高的实现方案. flex布局实现 ​ 猪齿鱼前端日常开发中,我们多以f ...

  5. RabbitMQ:从入门到搞定面试官

    安装 使用docker安装,注意要安装tag后缀为management的镜像(包含web管理插件),我这里使用的是rabbitmq:3.8-management 1. 拉取镜像 shell docke ...

  6. DevOps 时代的高效测试之路

    10 月 22 日,2021 届 DevOps 国际峰会在北京顺利召开,来自国内外的顶级技术专家共同畅谈 DevOps 体系与方法.过程与实践.工具与技术.CODING 测试及研发流程管理产品总监程胜 ...

  7. Mybatis 动态批量修改

    封面:学校夜景 xdm,祝大家节日快乐!! 今天听<路过人间>演唱会Live限定版,爱上了一句歌词. 说来惭愧,人对爱只学会,视死如归. 1.业务需求 如下: 前台传给我一个 docume ...

  8. 5.31日 Scrum Metting

    日期:2021年5月31日 会议主要内容概述:讨论草稿箱前后端接口,讨论账单页面设计. 一.进度情况 组员 负责 两日内已完成的工作 后两日计划完成的工作 工作中遇到的困难 徐宇龙 后端 文件导入功能 ...

  9. 聊聊 Kubernetes Pod or Namespace 卡在 Terminating 状态的场景

    这个话题,想必玩过kubernetes的同学当不陌生,我会分Pod和Namespace分别来谈. 开门见山,为什么Pod会卡在Terminationg状态? 一句话,本质是API Server虽然标记 ...

  10. spring social实现百度登录

    在早期我写过一篇spring social理解的文章,介绍了一些spring social的概念,但是没有提供一个例子.在这篇博客中,提供一个简单的spring social的例子,实现 百度登录,那 ...