mongo与关系型数据库的概念对比,区分大小写,_id为主键。

一、数据库操作

>show dbs或者show databases   #查看所有数据库

>use dbname    #创建和切换数据库(如果dbname存在则切换到该数据库,不存在则创建并切换到该数据库;新创建的数据库不会显示,需要插入记录才会显示)

>db.dropDatabase()  #删除数据库(需要先use进入到需要删除的数据库)

二、集合操作

>show collections或者show tables  #查看集合(需要先use进入数据库)

>db.createCollection(集合名字,参数)   #创建集合

>db.集合名.drop()   #删除集合

三、文档操作

在对文档做操作时,文档的字段名可以加引号,也可以不加引号。

1.插入文档 db.集合名.insert(文档)

如果集合在该数据库中不存在会先创建集合;文档为字典形式,可以是单个的字典,也可以是由字典组成的列表

>db.col.insert({
title: 'MongoDB教程',
description: 'MongoDB是一个Nosql数据库',
by: '菜鸟教程',
url: 'https://www.runoob.com/mongodb/mongodb-tutorial.html',
tags: ['mongodb', 'database', 'NoSQL'],
likes: 100
}) >db.col.insert({
title: 'MySQL教程',
description: 'MySQL是一个sql数据库',
by: '菜鸟教程',
url: 'https://www.runoob.com/mysql/mysql-tutorial.html',
tags: ['MySQL', 'database', 'SQL'],
likes: 200
})

插入文档也可以使用db.集合名.save(document) 命令,如果不指定 _id字段save() 方法类似于insert() 。

2.查询文档

db.集合名.find(查询条件,筛选列).pretty() ,查询条件和筛选列都通过字典形式表达

查询条件筛选行:多个条件and查询:find({'k1':'v1','k2':'v2',...}),相当于关系型数据库中的where k1=v1 and k2=v2 and ...

查询条件筛选行:多个条件or查询:find({ $or:[ {'k1':'v2'},{'k2':'v2'},...] }),相当于关系型数据库中的where k1=v1 or k2=v2 or

删选列:{'_id':0,'k1':1,'k2':1...},1表示返回0表示不返回,_id如果不指定为0默认表示返回,相当于关系型数据库中的select field1,field2,... from

在指定的所有列中,除了_id其他所有的值要么都为1,表示指定列返回未指定列不返回,要么都为0表示指定列不返回其他列返回

限定返回结果的数量:limit(n),返回查询结果的前n条

排序:sort({'key':1}),按照key字段排序,值为1则升序排,-1则降序排

find是以非结构化的形式显示所有文档,加上pretty()以结构化的形式显示,对应的findOne方法返回第一个满足条件的文档

> db.col.find({'title':'MongoDB教程'}).pretty()
{
"_id" : ObjectId("5d2e94f240515ad8a4693240"),
"title" : "MongoDB教程",
"description" : "MongoDB是一个Nosql数据库",
"by" : "菜鸟教程",
"url" : "https://www.runoob.com/mongodb/mongodb-tutorial.html",
"tags" : [
"mongodb",
"database",
"NoSQL"
],
"likes" : 100
}

mongo也支持逻辑查询,

例如

>db.col.find({'likes':{$gt:200,$lte:200}}).sort({'likes':1})

db.集合名.distinct(k)

获取所有不重复的k字段的值

3.更新文档

db.集合名.update(查询条件,更新操作,{upsert: <boolean>,multi: <boolean>,writeConcern: <document>})

  • 更新操作:形式为{ $set:{key:value} }
  • upsert : 可选,表示如果要update的记录不存在是否将其插入为新记录,默认是false不插入,true则插入。
  • multi : 可选,表示是否更新所有满足条件的记录,默认是false只更新找到的第一条记录,true则将满足条件的所有记录全部更新。
  • writeConcern :可选,抛出异常的级别。
> db.col.update({by:'菜鸟教程'},{$set:{likes:500}},{upsert:true,multi:true})
WriteResult({ "nMatched" : 2, "nUpserted" : 0, "nModified" : 2 })

db.集合名.save(文档)

如果不传入_id,则该方法类似insert(),会插入一个文档

如果传入_id,则会对_id进行判断,如果要save的记录在原集合中存在,则按照内容对已存在的文档进行更新,如果不存在则进行插入也类似insert()。

> db.col.save({
"_id" : ObjectId("5d2e960d40515ad8a4693241"),
title: 'Python教程',
description: 'Python是一种解释型、面向对象、动态数据类型的高级程序设计语言',
by: '菜鸟教程',
url: 'https://www.runoob.com/python3/python3-tutorial.html',
tags: ['Python', '开发', '编程'],
likes: 1000
 })
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
db.col.save({
"_id" : ObjectId("5d2e960d40515ad8a4693250"),
title: 'HTML',
description: '是一种用于创建网页的标准标记语言',
by: '菜鸟教程',
url: 'https://www.runoob.com/html/html-tutorial.html',
tags: ['HTML', '前端', '编程'],
likes: 300
})
WriteResult({ "nMatched" : 0, "nUpserted" : 1, "nModified" : 0 })

4.删除文档 db.集合名.remove(queryjustOne,writeConcern )

  • query :(可选)删除文档的条件,用字典形式表示。
  • justOne : (可选)如果设为 true 或 1,只删除一个文档,不设置该参数使用默认值 false,删除所有匹配条件的文档。
  • writeConcern :(可选)抛出异常的级别。
>db.col.remove({by:'菜鸟教程'},1)
WithResult({"nRemoved":1})
>db.col.remove({by:'菜鸟教程'})
WithResult({"nRemoved":2})

db.col.remove({})删除所有文档

MongoDB基本使用方法的更多相关文章

  1. MongoDB中insert方法、update方法、save方法简单对比

    MongoDB中insert方法.update方法.save方法简单对比 1.update方法 该方法用于更新数据,是对文档中的数据进行更新,改变则更新,没改变则不变. 2.insert方法 该方法用 ...

  2. Linux安装mongoDB步骤和方法

    Linux安装mongoDB步骤和方法 下载mongoDB数据库 mongodb-linux-x86_64-3.0.15.tgz 存放到linux文件夹中 ftp软件直接拖上去 解压文件夹(解压后,会 ...

  3. MongoDB 查询 $关键词 方法目录

    MongoDB $关键字 关系比较符号 $lt $lte $gt $gte $ne MongoDB 查询$关键字 $in $or $all MongoDB limit 选取 skip跳过 sort排序 ...

  4. 在windows7 32ibt安装MongoDB数据库的方法及连接失败解决方案

    参考 https://www.cnblogs.com/cnblogs-jcy/p/6734889.html http://yunkus.com/mongodb-install-config-in-wi ...

  5. mongodb 常见问题处理方法收集

    问题1:非正常关闭服务或关机后 mongod服务无法正常启动 在使用中发现mongodb 的服务可能因为非正常关闭而启动不了,这时我们通过 删除data目录下的 *.lock文件,再运行下/mongo ...

  6. MongoDB 镜像配置方法

    镜像下载.域名解析.时间同步请点击 阿里巴巴开源镜像站 MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. 配置方法 安装 ...

  7. PHP 操作mongodb api大部分方法

    <?php /* PHP mongodb * 全部curd操作 * @author:xiaojiang * @date: 2014-10-27 */ //查看 mongo类版本 1.30 以后版 ...

  8. mongodb的安装方法

    下载安装 mongodb官网下载地址:https://www.mongodb.org/downloads#produc...直接下载.msi文件并安装到指定目录即可.我的安装路径是D:\mongodb ...

  9. mac下设置mongodb开机启动方法

    Mac OS 的开机启动方式 launchd 是 Mac OS 下用于初始化系统环境的关键进程,它是内核装载成功之后在OS环境下启动的第一个进程.其实它的作用就是我们平时说的守护进程,简单来说,用户守 ...

随机推荐

  1. Hexo快速构建个人小站-Fulid主题下添加Valine评论系统(三)

    Hexo目录: Hexo快速构建个人小站-Hexo初始化和将项目托管在Github(一) Hexo快速构建个人小站-自定义域名和自定义主题(二) 背景交代: 前面两章完成了Hexo的初始化和部分自定义 ...

  2. Netty源码学习系列之5-NioEventLoop的run方法

    前言     NioEventLoop的run方法,是netty中最核心的方法,没有之一.在该方法中,完成了对已注册的channel上来自底层操作系统的socket事件的处理(在服务端时事件包括客户端 ...

  3. CSS通过text-transform实现大写、小写和首字母大写转换

    再日常项目中可能会用到一些特殊的样式,比如大写字母转小写.小写字母转大写.首字母大写等. 可以通过 CSS 的 text-transform 属性来实现: text-transform 转换不同的文本 ...

  4. Flv.js文档使用随记

    关键字:Flv.js | Flv js | Flv-js | HTML5 FLV Player | 0x001: 前言以下涉及到 flv.js 所有内容均是V1.5.0版本内的,如方法.属性.常量.监 ...

  5. 状压DP之Mixed Up Cows G

    题目 传送们 大意 约翰家有N头奶牛,第i头奶牛的编号是Si,每头奶牛的编号都是唯一的.这些奶牛最近 在闹脾气,为表达不满的情绪,她们在挤奶的时候一定要排成混乱的队伍.在一只混乱的队 伍中,相邻奶牛的 ...

  6. A*算法求K短路模板 POJ 2449

    #include<cstdio> #include<queue> #include<cstring> using namespace std; const int ...

  7. JavaScript学习 Ⅳ

    八. 批量创建对象 使用工厂方法创建对象 function creatPerson(name, age, gender='男'){ var obj = new Object(); obj.name = ...

  8. 数据可视化之powerBI基础(二)PowerBI动态图表技巧:钻取交互

    https://zhuanlan.zhihu.com/p/64406366 查看可视化图表的时候,我们可能想深入了解某个视觉对象的更详细信息,或者进行更细粒度的分析,比如看到2017年的总体数据,同时 ...

  9. redis(十五):Redis 有序集合(sorted set)(python)

    #coding:utf8 import redis r =redis.Redis(host="23.226.74.190",port=63279,password="66 ...

  10. 一个HashMap能跟面试官扯上半个小时

    一个HashMap能跟面试官扯上半个小时 <安琪拉与面试官二三事>系列文章 一个HashMap能跟面试官扯上半个小时 一个synchronized跟面试官扯了半个小时 一个volatile ...