什么是MongoDB ?(引用菜鸟教程

MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。

在高负载的情况下,添加更多的节点,可以保证服务器性能。

MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。

MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
主要特点

  1. MongoDB 是一个面向文档存储的数据库,操作起来比较简单和容易。
  2. 你可以在MongoDB记录中设置任何属性的索引 (如:FirstName=“Sameer”,Address=“8 Gandhi Road”)来实现更快的排序。
  3. 你可以通过本地或者网络创建数据镜像,这使得MongoDB有更强的扩展性。
  4. 如果负载的增加(需要更多的存储空间和更强的处理能力) ,它可以分布在计算机网络中的其他节点上这就是所谓的分片。
  5. Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。
  6. MongoDb 使用update()命令可以实现替换完成的文档(数据)或者一些指定的数据字段 。
  7. Mongodb中的Map/reduce主要是用来对数据进行批量处理和聚合操作。
  8. Map和Reduce。Map函数调用emit(key,value)遍历集合中所有的记录,将key与value传给Reduce函数进行处理。
  9. Map函数和Reduce函数是使用Javascript编写的,并可以通过db.runCommand或mapreduce命令来执行MapReduce操作。
  10. GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件。
  11. MongoDB允许在服务端执行脚本,可以用Javascript编写某个函数,直接在服务端执行,也可以把函数的定义存储在服务端,下次直接调用即可。
  12. MongoDB支持各种编程语言:RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
  13. MongoDB安装简单。

语言支持
MongoDB有官方的驱动如下:

C
C++
C# / .NET
Erlang
Haskell
Java
JavaScript
Lisp
node.JS
Perl
PHP
Python
Ruby
Scala

数据库操作

  1. 创建数据库
    use 数据库名字------如果数据库不存在则创建,存在则切换
  2. 查看所有数据库(空数据库不显示)
    show dbs
  3. 查看当前使用的数据库
    db
  4. 要显示新创建的数据库,至少插入一个文档
    db.items.insert({’‘key’’:“value”})
    key value 是键值对
  5. 删除数据库
    db.dropDatabase() ------- 删除现有数据库

数据库中集合操作

  1. 创建一个MongoDB数据库中集合
    格式:
    db.createCollection(name,options)
    name----string-----要创建数据库的名称
    options-----Document-----可选,指定有关内存大小和索引选项

字段

类型

描述

capped

bollean

如果true—>启用封闭的集合,上限集合的固定大小,和size参数联用

size

数字

指定上限集合的最大大小(字节)

max

数字

上限集合中允许存储的最大文档数

autoIndexId

Boolean

可选,如果true,创建字段_id 并自动创建索引 默认为false

db.createClooection(‘mycol’,{capped:true,autoIndexId:true,size:6140000,max:10000})

  1. 显示当前数据库所有集合
    show collections
  2. 删除集合
    db.集合名字.drop()
    db.collection.drop()----删除当前集合
    如果删除成功----true
    删除失败-----false

文档操作

  1. 插入文档
    两种方式: insert() , save()
    insert()格式:
    db.集合名字.insert(内容插入)
    例如:mycol集合
    db.mycol.insert({_id:100,title:‘mongodb overview’,description:‘mongodb is no sql database’,url:‘http://www.baidu.com’,tags:[‘mongodb’,‘database’,‘nosql’],likes:100,})
    save()格式:
    db.post.save(document)
    3.2 版本至少在3.2
    insertone()----可以插入单个文本
    insertmany()----可以插入多个文本
  2. 查询文档
    要从mongodb中集合中查询数据----》find()
    格式:
    db.collection_name.find()
    find()----查询----返回是一个非结构化的显示所有的文档
    db.collection_name.find().pretty()---->格式化显示查询的数据
  3. mongoDb和RDBMS的等效的where语句
    relational database management system(关系型数据库管理系统)
    mysql:
    select * from mycol where _id=104;
    mongodb:
    db.mycol.find(过滤的规则)
    (1) 过滤规则
  4. mongodb能写sql语句吗 mongodb用什么语言操作_数据

  5. (2)mongodb中and操作符
    (3)mongodb中or操作符
    (4)使用and和or条件一起使用

更新中…