一、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的基本操作的更多相关文章

  1. Mongodb学习笔记二(Mongodb基本命令)

    第二章 基本命令 一.Mongodb命令 说明:Mongodb命令是区分大小写的,使用的命名规则是驼峰命名法. 对于database和collection无需主动创建,在插入数据时,如果databas ...

  2. Mongodb 笔记01 MongoDB 简介、MongoDB基础知识、启动和停止MongoDB

    MongoDB 简介 1. 易于使用:没有固定的模式,根据需要添加和删除字段更加容易 2. 易于扩展:MongoDB的设计采用横向扩展.面向文档的数据模型使它能很容易的再多台服务器之间进行分割.自动处 ...

  3. mongodb篇二:mongodb克隆远程数据库,去重查询的命令及对应java语句

    http://blog.csdn.net/qkxh320/article/details/16115671 1.首先操作mongodb最基本命令:: show databases;           ...

  4. awk学习笔记二:调用shell、文件执行(转)

    awk 'BEGIN {print "Hello"}' 不操作文件直接处理数据流 要调用shell则可以用管道命令 如,打印日期awk 'BEGIN {"date&quo ...

  5. MongoDB学习笔记二—Shell操作

    数据类型 MongoDB在保留JSON基本键/值对特性的基础上,添加了其他一些数据类型. null null用于表示空值或者不存在的字段:{“x”:null} 布尔型 布尔类型有两个值true和fal ...

  6. MongoDB学习笔记二- Mongoose

    MongoDB学习笔记二 Mongoose Mongoose 简介 之前我们都是通过shell来完成对数据库的各种操作, 在开发中大部分时候我们都需要通过程序来完成对数据库的操作 而Mongoose就 ...

  7. MongoDB笔记(一):MongoDB介绍及Windows下安装

    一.前言 MongoDB火了也蛮久了,关于简介看看这里吧.项目中一直没用上,最近闲的慌就自己学了下,顺便记录下以便今后复习. 本系列是基于MongoDB 2.4.8 windows 64位讲解,后面的 ...

  8. MongoDB学习笔记二:使用Docker安装MongoDB

    目录 Docker安装MongoDB Docker给MongoDB设置用户密码 NoSQL Manager for MongoDB连接 为admin赋权限 上一个笔记介绍了Windows下安装Mong ...

  9. nodejs学习笔记二——链接mongodb

    a.安装mongoose库用来链接mongodb数据库 安装mongodb数据库参考mongodb安装 前言(怨言) 本来是想安装mongodb库来链接mongodb的,命令行到nodejs工程目录: ...

随机推荐

  1. (十)while和until循环

    (1)while循环 语法:当条件测试成立(真),执行循环体 while 条件测试 do 循环体 done 1)while批量创建用户1 从user.txt读取到的行数据赋予给变量user值 #!/b ...

  2. MySQL数据库增删改字段(属性)

    MySQL数据库的各种操作今天在这里总结一下: 一.增加 1.在已有的表中添加新的字段: 首先是增加表的字段,比如一张表原本没有字段“ Time ”,现在我们要增加这样一个字段,可以用下面的SQL语句 ...

  3. AxureRP7超强部件库打包下载

    摘要: 很多刚刚开始学习Axure的朋友都喜欢到网上搜罗各种部件库(组件库)widgets library ,但是网络中真正实用的并且适合你使用的少之又少,最好的办法就是自己制作适合自己工作内容的部件 ...

  4. [CF509F]Progress Monitoring

    题目大意: 给定一个树的DFS序$b_1,b_2,\ldots,b_n$($b$为$1\sim n$的一个排列且$b_1=1$).同一个结点的子结点按照结点编号从小到大遍历.问有多少种可能的树的形态? ...

  5. fidder模拟post提交到PHP遇到的问题

    http头必须带上Content-type: application/x-www-form-urlencoded  之后 ,php 才能接收到post数据 1. 用php://input可以很便捷的取 ...

  6. JQurey中getJSON方法错误回调方法

    1.使用try...catch实现 2.换$.ajax 3.JQuery 1.5+可以这样使用: $.getJSON("example.json", function() { al ...

  7. CASJAVA一些理解

    如果不用锁机制如何实现共享数据访问.(不要用锁,不要 用sychronized  块或者方法,也不要直接使用 jdk  提供的线程安全的数据结构,需要自己实现一个类来保证多个线程同时读写这个类中的共享 ...

  8. spring+activity+mysql集群

     第一步:先配置好第一个activityMQ 在broker外面加入数据库的连接信息,并将mysql的mysql-connector-java.jar,即java连接mysql的jar包放入apach ...

  9. CentOS--在CentOS安装PHP5.6

    查看centos的版本: [root@localhost ~]# lsb_release -a LSB Version:    :core-3.1-amd64:core-3.1-ia32:core-3 ...

  10. rundll32.exe的相关使用语句

    命令列: rundll32.exe shell32.dll,Control_RunDLL 功能: 显示控制面板 命令列: rundll32.exe shell32.dll,Control_RunDLL ...