MongoDB笔记(二):MongoDB下Shell的基本操作
一、mongoDB与关系型数据库对比
| 对比项 | mongoDB | 关系型数据库(oracle、mysql) |
| 表 | 集合List | 二维表table |
| 表的一行数据 | 文档document | 一条记录record |
| 表字段 | 键key | 字段field |
| 字段值 | 值value | 值value |
| 主外键 | 无 | PK、FK |
| 灵活扩展性 | 极高 | 差 |
二、mongoDB基本的Shell命令
1、创建数据库、操作表之前需要先启动mongoDB数据库(既启动服务端):
启动服务:
> mongod --dbpath C:\mongodb\data
使用admin连接:
> mongo 127.0.0.1:27017/admin
注:若使用mongo 127.0.0.1:27017连接,则默认是test用户连接
2、创建一个数据库caliven:
> use [databaseName]
> use caliven
注:使用use命令,只是创建了一个空的数据库,若不做任何操作离开时空数据库会被删除
3、查看所有数据库:
> show dbs
4、创建一个集合并增加一条记录:
> db.[collectionName].insert({...})
> db.users.insert({name:"Jack"})
注:mongoDB会默认为每条记录插入一个"_id"的字段,{...}中的数据是BSON形式的数据
5、查看数据库所有集合:
> show collections
6、查询指定集合的数据:
查询所有:
> db.[collectionName].find()
> db.users.find()
查询第一条:
> db.[collectionName].findOne()
> db.users.findOne()
7、更新集合数据:
> db.[collectionName].update({查询器}, {更新内容})
> db.users.update({name:"Jack"}, {$set:{name:"Tom"}})
> var u = db.users.findOne()
> db.users.update(u, {name:"Tom"})
8、删除集合数据:
> db.[collectionName].remove({查询器})
> db.users.remove({name:"Jack"})
9、删除数据库的集合:
> db.[collectionName].drop()
> db.users.drop()
10、删除数据库:
> db.dropDatabase()
11、Shell的help:
> db.help() 可查看关于操作数据库的一些命令
> db.[collectionName].help() 可查看关于操作集合的一些命令
12、数据库和集合的命名规范:
1> 应全部小写;
2> 不能是空字符串;
3> 不能含有特殊字符,如:' ' , $ / \ 等;
4> 长度最多64个字节;
5> 数据库名称不能与现有系统保留库同名,如:admin、local、config;
6> 名称中最好不要带"-",如"test-db",虽然合法,但操作起来比较麻烦。
13、mongoDB的shell内置javascript引擎,可以直接执行javascript代码,如eval,function xxx(){.....}等。
mongoDB 2.4.8版本的API文档地址:http://api.mongodb.org/js/2.4.8/index.html
可以看看图中的相关shell执行后的效果:

在shell中执行javascript代码:

未完待续。。。。。。
MongoDB笔记(二):MongoDB下Shell的基本操作的更多相关文章
- Mongodb学习笔记二(Mongodb基本命令)
第二章 基本命令 一.Mongodb命令 说明:Mongodb命令是区分大小写的,使用的命名规则是驼峰命名法. 对于database和collection无需主动创建,在插入数据时,如果databas ...
- Mongodb 笔记01 MongoDB 简介、MongoDB基础知识、启动和停止MongoDB
MongoDB 简介 1. 易于使用:没有固定的模式,根据需要添加和删除字段更加容易 2. 易于扩展:MongoDB的设计采用横向扩展.面向文档的数据模型使它能很容易的再多台服务器之间进行分割.自动处 ...
- mongodb篇二:mongodb克隆远程数据库,去重查询的命令及对应java语句
http://blog.csdn.net/qkxh320/article/details/16115671 1.首先操作mongodb最基本命令:: show databases; ...
- awk学习笔记二:调用shell、文件执行(转)
awk 'BEGIN {print "Hello"}' 不操作文件直接处理数据流 要调用shell则可以用管道命令 如,打印日期awk 'BEGIN {"date&quo ...
- MongoDB学习笔记二—Shell操作
数据类型 MongoDB在保留JSON基本键/值对特性的基础上,添加了其他一些数据类型. null null用于表示空值或者不存在的字段:{“x”:null} 布尔型 布尔类型有两个值true和fal ...
- MongoDB学习笔记二- Mongoose
MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ...
- MongoDB笔记(一):MongoDB介绍及Windows下安装
一.前言 MongoDB火了也蛮久了,关于简介看看这里吧.项目中一直没用上,最近闲的慌就自己学了下,顺便记录下以便今后复习. 本系列是基于MongoDB 2.4.8 windows 64位讲解,后面的 ...
- MongoDB学习笔记二:使用Docker安装MongoDB
目录 Docker安装MongoDB Docker给MongoDB设置用户密码 NoSQL Manager for MongoDB连接 为admin赋权限 上一个笔记介绍了Windows下安装Mong ...
- nodejs学习笔记二——链接mongodb
a.安装mongoose库用来链接mongodb数据库 安装mongodb数据库参考mongodb安装 前言(怨言) 本来是想安装mongodb库来链接mongodb的,命令行到nodejs工程目录: ...
随机推荐
- atom 插件
来源 个人博客 http://taoquns.com/paper/59ba5627a157197cdcc0a012 输入类 autocomplete-plus emmet go-to-line ato ...
- tomcat虚拟主机
直接看配置文件吧,有点基础的都懂 <Host name="localhost" appBase="webapps" unpackWARs="fa ...
- cobbler自动重装
如果物理机上想更换操作系统 yum -y install http://mirrors.163.com/centos/7/extras/x86_64/Packages/epel-release-7-9 ...
- 2014年spark开发者大赛火热进行中!
“发现最有正能量的网络达人”,Spark开发者大赛火热进行! 2014年9月30日,2014 Spark开发者大赛在北京正式启动.本次大赛由Spark亚太研究院联合国内领先的IT技术创新与发展的互联网 ...
- FZU 2150 Fire Game 【两点BFS】
Fat brother and Maze are playing a kind of special (hentai) game on an N*M board (N rows, M columns) ...
- linux程序与进程内存结构
1.可执行文件结构: 1)代码区:包含操作码和操作对象.常量数据(const声明).立即数,代码区是共享的, 只提供只读. 2)全局/静态数据区:包含被初始化的全局数据和初始化静态数据. 3)未初始化 ...
- hdu6059( Trie )
hdu6059 题意 给定数组 \(A\) ,问有多少对下标 \((i, j, k)\) 满足 \(i < j < k\) 且 \((A[i] \ xor \ A[j]) < (A[ ...
- ASP.NET Core 2.2 基础知识(十二) 发送 HTTP 请求
可以注册 IHttpClientFactory 并将其用于配置和创建应用中的 HttpClient 实例. 这能带来以下好处: 提供一个中心位置,用于命名和配置逻辑 HttpClient 实例. 例如 ...
- 打印不同的数 Exercise07_05
import java.util.Scanner; /** * @author 冰樱梦 * 时间:2018年下半年 * 题目:打印不同的数 * */ public class Exercise07_0 ...
- Spring的Aop 注解配置
1,导包 2,准备目标对象 package com.songyan.anno; public interface UserService { void save(); void delete(); v ...