MongoDB 学习(一)

1. MongoDB 简介

  1. MongoDB 是一个基于分布式 文件存储的NoSQL数据库
  2. 由C++语言编写,运行稳定,性能高
  3. 旨在为 WEB 应用提供可扩展的高性能数据存储解决方案

2. MongoDB 特点

  1. 模式自由 :可以把不同结构的文档存储在同一个数据库里
  2. 面向集合的存储:适合存储 JSON风格文件的形式
  3. 完整的索引支持:对任何属性可索引
  4. 复制和高可用性:支持服务器之间的数据复制,支持主-从模式及服务器之间的相互复制。复制的主要目的是提供冗余及自动故障转移
  5. 自动分片:支持云级别的伸缩性:自动分片功能支持水平的数据库集群,可动态添加额外的机器
  6. 丰富的查询:支持丰富的查询表达方式,查询指令使用JSON形式的标记,可轻易查询文档中的内嵌的对象及数组
  7. 快速就地更新:查询优化器会分析查询表达式,并生成一个高效的查询计划
  8. 高效的传统存储方式:支持二进制数据及大型对象(如照片或图片)

3. 基本操作

  1. MongoDB将数据存储为一个文档,数据结构由键值(key=>value)对组成
  2. MongoDB文档类似于JSON对象,字段值可以包含其他文档、数组、文档数组
    SQL术语/概念 MongoDB术语/概念 解释/说明
    database database 数据
    table collection 数据库表/集合
    row document 数据记录行/文档
    column field 数据字段/域
    index index 索引
    table joins 表连接,MongoDB不支持
    primary key primary key 主键,MongoDB自动将_id字段设置为主键
  3. 三元素:数据库、集合、文档
    1. 集合就是关系数据库中的表
    2. 文档对应着关系数据库中的行
  4. 文档,就是一个对象,由键值对构成,是json的扩展Bson形式
    {'Web':'ccblogs','www':'com'}
    
  5. 集合:类似于关系数据库中的表,储存多个文档,结构不固定,如可以存储如下文档在一个集合中
    {'Web1':'ccblogs1','www1':'com1'}
    {'Web2':'ccblogs2','www2':'com2'}
    {'Web3':'ccblogs3','www3':'com3'}
    
  6. 数据库:是一个集合的物理容器,一个数据库中可以包含多个文档
  7. 一个服务器通常有多个数据库

4. MongoDB安装

  1. 在centos系统的 /etc/yum.repos.d/ 路径下创建 mongodb-enterprise.repo 文件,并在文件内输入下面的内容:
    [mongodb-enterprise]
    name=MongoDB Enterprise Repository
    baseurl=https://repo.mongodb.com/yum/redhat/$releasever/mongodb-enterprise/3.4/$basearch/
    gpgcheck=1
    enabled=1
    gpgkey=https://www.mongodb.org/static/pgp/server-3.4.asc
    
  2. 使用管理员权限执行下面的命令安装数据库:
    yum install -y mongodb-enterprise
    
  3. 开启数据库服务:
    service mongod start
    
  4. 关闭数据库服务:
    service mongod stop
    
  5. 重启数据库服务:
    service mongod restart
    
  6. 数据库相关信息:
    1. 配置文件在/etc/mongod.conf
    2. 默认端口27017
发布了31 篇原创文章 · 获赞 3 · 访问量 2305

猜你喜欢

转载自blog.csdn.net/ccblogs/article/details/104647972