1. MongoDB的安装方法

(1)下载MongoDB 相应的版本;

(2)设置数据文件和日志文件的存放目录;

(3)启动MongoDB服务;

(4)将MongoDB作为服务启动。

2. MongoDB文档基本操作的方法

(1)插入并保存文档;

(2)删除文档;

(3)修改文档。

一、数据库操作

use database_name,如果数据库不存在将创建一个新的数据库;

否则将返回现有的数据库。

db                                              --显示当前选择的数据库

use mydb                                        --创建或切换数据库

db

show dbs                                        --显示所有数据库,没有刚建立的mydb

db.movie.insert({"name":"tutorials yiibai"})    --要显示的数据库,需要把它插入至少一个文件。

show dbs

db.dropDatabase()                               --删除数据库

show dbs

db命令显示的还是mydb,但是没有数据。

二、集合操作

a.显式创建集合

db.createCollection(name, options):name 是要创建的集合的名称. Options 是一个文件,用于指定配置的集合

db.createCollection("movie")

show collections

db.movie.drop()

show collections

b.隐式创建集合

db.movie.insert({"name":"tutorials yiibai"})

show collections                           --查询所有集合

db.getCollectionNames()                    --查询所有集合

db.movie.count()                           --查看集合中文档总数据量

db.movie.dataSize()                        --查看集合空间大小

db.movie.getDB()                           --查看集合所在数据库

db.movie.stats()                           --查看当前集合状态

db.movie.renameCollection("movies")        --集合重命名

show collections

db.movies.copyTo("movie")                  --集合复制

db.movies.drop()                           --删除集合

db.movie.help()                            --查看集合帮助

db.getCollection("movie")                  --得到指定名称的聚集集合

db.printCollectionStats()                  --显示当前db所有聚集索引的状态

三、文档操作

3.文档操作-插入操作

1.插入操作

a.单个插入

db.movie.insert({"name":"HuanLeSong","Times":10000})

db.movie.insert({"name":"SanJie","Times":20000})

db.movie.insert({"name":"SanJie","Address":"China"})

db.movie.find()

movieVar1 = {"name":"HuanLeSong","Times":10000};  --创建文档变量,对象

movieVar2 = {"name":"SanJie","Times":20000};

movieVar3 = {"name":"SanJie","Address":"China"};

db.movie.insert(movieVar1)

db.movie.insert(movieVar2)

db.movie.insert(movieVar3)

db.movie.find()

db.movie.insert({"_id":08001,"name":"zhangsan"})

db.movie.find()

db.movie.insert({"_id":08001,"name":"lisi"})

db.movie.save({"_id":08001,"name":"lisi"})

db.movie.find()

Insert和Save的区别是:如果插入的集合的“_id”值,在集合中已经存在,用Insert执行插入操作会报异常,已经存在"_id"的键。用Save如果系统中没有相同的"_id"就执行插入操作,有的话就执行覆盖掉原来的值。相当于修改操作。

b.批量插入

采用数组的方式

db.movie.insert([{username:'aaa',password:'bbb',tel:'123123123'},{username:'bbb',password:'ccc',tel:'123123234'}]);

db.movie.find()

2.删除操作

db.movie.find()

db.movie.remove({"name":"HuanLeSong"})  --按条件删除

db.movie.find()

db.movie.remove({})                     --删除所有(集合本身不删除)

db.movie.find()

show collections

db.movie.drop()                         --删除所有(集合带文档)

db.movie.find()

show collections

remove({})和drop()的区别:

remove({}):删除所有文档,但不会删除集合本身,原索引也会保留

drop():删除整个集合,包括索引,然后重新创建集合和建立索引

3.修改操作

文档存入数据库后,就可以用update方法来修改它,update有两个参数一个是查询文档,找出需要更新的文档。一个是修改文档,描述对找到的文档做哪些修改

更新操作是原子的,若是两个更新同时发生,先到达服务器的先执行。

a.替换更新update

db.movie.update({username:"bbb"},{password:"abc"});

db.movie.find()

b.修改器更新

I.$set修改器

$set用来指定一个键的值,如果这个键不存在,就创建它。并且,只修改第一个

db.movie.update({username:"aaa"},{$set:{password:"*****"}});

db.movie.find()

II.$unset修改器

$unset来删除一个键

db.movie.update({username:"aaa"},{$unset:{tel:1}});

db.movie.find()

III.$inc修改器

$inc用来增加已有的键值,或者在键值不存在时创建。

db.movie.update({username:"aaa"},{$inc:{age:2}});  --键值age不存在,创建age并赋值2

db.movie.find()

db.movie.update({username:'aaa'},{$inc:{age:2}});   --在原有的值上 age+2

db.movie.find()

IV.upsert

当update的第三个参数设置为true的时候,为upsert模式

upsert是一个特殊的更新。当没有文档符合更新条件,就会以这个条件创建新的文档。

db.movie.update({username:'aaa'},{$set:{abc:123}},true)        --当没有文档符合更新条件,就会以这个条件创建新的文档

db.movie.find()

db.movie.update({username:'aaa'},{$set:{abc:234}},true)        --当文档符合更新条件,就会更新文档

db.movie.find()

V.数组修改器

数组修改器只能用于数组。

$push会像已有的数组末尾添加一个元素

$pop会删除一个元素

db.movie.update({username:'aaa'},{$push:{arr:1}});

db.movie.find()

db.movie.update({username:'aaa'},{$push:{arr:2}});

db.movie.find()

db.movie.update({username:'aaa'},{$push:{arr:5}});

db.movie.find()

db.movie.update({username:'aaa'},{$push:{arr:3}});

db.movie.find()

db.movie.update({username:'aaa'},{$pop:{arr:1}}); pop原本是正向删除数组最后一个元素,取负号后-后倒序删除

db.movie.find()

db.movie.update({username:'aaa'},{$pop:{arr:-1}});

db.movie.find()

VI.数组的定位修改器

若是数组中多个值,我们只想修改其中的部分值,有两种方法操作数组中的值:通过位置和定位操作符($)

数组下标是从0开始

db.movie.update({username:'aaa'},{$set:{'arr.2':10}}); 数组第三个元素插入数值10

db.movie.find()

db.movie.update({'arr.2':10},{$set:{'arr.$':100}});  数组第三个元素替换为100

db.movie.find()

VII.多文档修改

第四个参数设置为true

db.movie.insert([{username:'aaa',password:'bbb',tel:'123123123'},{username:'bbb',password:'ccc',tel:'123123234'}]);

db.movie.update({username:"aaa"},{$set:{password:"******"}},false,true);

db.movie.find()

MongoDB文档的基本操作的更多相关文章

  1. mongoDB 文档概念

    mongoDB 文档概念 什么是文档 文档是 mongodb 基本的数据组织单元,类似于mysql 中的记录 文档由多个键值对组成,每个键值对表达一个数据项 属于 bson 数据 ps:  bson ...

  2. mongoDB 文档操作_删

    mongoDB 文档删除 MySQL对比 mysql delete from table where ... mongo db.collection.deleteOne(query) 删除函数 del ...

  3. Lucene7.2.1系列(二)luke使用及索引文档的基本操作

    系列文章: Lucene系列(一)快速入门 Lucene系列(二)luke使用及索引文档的基本操作 Lucene系列(三)查询及高亮 luke入门 简介: github地址:https://githu ...

  4. mongodb文档支持的数据类型

    版权声明:转载请标明来源. https://blog.csdn.net/u014285882/article/details/25510377 1. 存储类型 mongodb文档相似于json,但不是 ...

  5. MongoDB文档基本操作

    一.插入文档 使用insert()或save()方法向集合插入文档 >db.COLLECTION_NAME.insert(document) 详细用法可以参考MongoDB菜鸟教程 二.查找文档 ...

  6. mongodb文档的CRUD

    本章会介绍对数据库移入或者移出数据的基本操作 向集合添加文档 从集合删除文档 更新现有的文档 为这些操作选择合适的安全级别 添加删除数据库 添加数据库 :use foo  如果存在foo 就use   ...

  7. MongoDB 文档的查询和插入操作

    MongoDB是文档型数据库,有一些专门的术语,和关系型DB相似,但也有差异,例如,Collection类似于关系型DB的Table,document类似于row,key/value pair类似于c ...

  8. 3.从Node.js操作MongoDB文档

    1.更新文档结构,而非SQL 2.数据库更新运算符 在MongoDB中执行对象的更新时,需要确切的指定需要改变什么字段.需要如何改变.不像SQL语句建立冗长的查询字符串来定义更新. MongoDB中可 ...

  9. MongoDB文档、集合、数据库简介

    文档 概述 文档是MongoDB的核心概念,是数据的基本单元,非常类似于关系数据库中的行.在MongoDB中,文档表示为键值对的一个有序集.MongoDB使用Javascript shell,文档的表 ...

随机推荐

  1. springboot搭建环境整合jsp页面整合mybatis

    1.pom文件依赖 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www ...

  2. springmvc异步上传图片并回调页面函数插入图片url代码示例

    <tr> <td class="search_td">属性值图片值:</td> <td> <input type=" ...

  3. HDU 6203 ping ping ping(dfs序+LCA+树状数组)

    http://acm.hdu.edu.cn/showproblem.php?pid=6203 题意: n+1 个点 n 条边的树(点标号 0 ~ n),有若干个点无法通行,导致 p 组 U V 无法连 ...

  4. AmazeUI学习

    http://amazeui.org/ 相比于其他国外的框架而言,Amaze UI更关注中文排版,被前端工程师称为最懂中文的前端框架. Amaze UI受欢迎的一个重要的原因是:文档非常完善,适合各阶 ...

  5. Windows系统零开始前端开发环境配置

    1. 安装nodejs 国内下载页面(推荐) 官网下载页面 现在的nodejs自带NPM,只需点击下一步下一步安装即可. 为了加速国内NPM包下载,可配置淘宝NPM镜像 2. 安装git 国内下载页面 ...

  6. mybatis+spring boot, mapper 提示Could not autowire. No beans of … type found

    工具及背景: IntelliJ IDEA 2016.1.3 Ultimate.spring boot, maven项目,利用mybatis 注解的方式查询mysql. 业务逻辑关系:controlle ...

  7. HttpDns原理

    什么是 DNS DNS(Domain Name System,域名系统),DNS 服务用于在网络请求时,将域名转为 IP 地址.能够使用户更方便的访问互联网,而不用去记住能够被机器直接读取的 IP 数 ...

  8. P1005 矩阵取数游戏

    传送门 思路: △ 区间动规 对于每行,有 f [ i ][ j ] 代表取区间 [ i , j ] 的最大值. 然后转移方程我们考虑,对于每一个新的 f [ i ][ j ],有两种情况(下面定义  ...

  9. 详解Vue中watch的高级用法

    我们通过实例代码给大家分享了Vue中watch的高级用法,对此知识点有需要的朋友可以跟着学习下. 假设有如下代码: <div> <p>FullName: {{fullName} ...

  10. C++.运行时类型判断_测试代码

    ZC:C++ 编程思想——运行时类型识别 - 浅墨浓香 - 博客园.html(https://www.cnblogs.com/5iedu/articles/5585895.html) -------- ...