1.什么是MongoDB?
1.MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。 在高负载的情况下,添加更多的节点,可以保证服务器性能。
2.MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
3.MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组
2.MongoDB的特点
1.模式自由 :可以把不同结构的文档存储在同一个数据库里
2.面向集合的存储:适合存储 JSON风格文件的形式
3.完整的索引支持:对任何属性可索引
4.复制和高可用性:支持服务器之间的数据复制,支持主-从模式及服务器之间的相互复制。复制的主要目的是提供冗余及自动故障转移
5.自动分片:支持云级别的伸缩性:自动分片功能支持水平的数据库集群,可动态添加额外的机器
6.丰富的查询:支持丰富的查询表达方式,查询指令使用JSON形式的标记,可轻易查询文档中的内嵌的对象及数组
7.快速就地更新:查询优化器会分析查询表达式,并生成一个高效的查询计划
8.高效的传统存储方式:支持二进制数据及大型对象(如照片或图片)
3.三元素: 数据库、集合、文档
4.数据库基本命令
show dbs 列出所有在物理上存在的数据库
db 当前数据库 use 数据库名称 切换数据库,如果数据库不存在就创建
db.stats() 查看当前数据库信息 db.dropDatabase() 删除当前数据库
db.createCollection(name, options) 创建集合
name是要创建的集合的名称 options是一个文档,用于指定集合的配置 选项参数是可选的,所以只需要到指定的集合名称
show collections:当前数据库的集合数。 db.集合名称.drop() 删除集合
db.集合名称.insert(document) 单条插入 db.集合名称.find() 查询全部文档
5.比较运算符
等于,默认是等于判断,没有运算符
小于$lt
小于或等于$lte
大于$gt
大于或等于$gte
不等于$ne
6.Mongodb的备份和恢复
mongodump -h dbhost -d dbname -o dbdirectory
-h: MongDB所在服务器地址,例如:127.0.0.1,当然也可以指定端口号:127.0.0.1:27017
-d: 需要备份的数据库实例,例如:test
-o: 备份的数据存放位置,例如:c:\data\dump,当然该目录需要提前建立,在备份完成后,系统自动在dump目录下建立一个test目录,这个目录里面存放该数据库实例的备份数据。
恢复备份
mongodb使用 mongorestore 命令来恢复备份的数据。
mongorestore -h hostname:port -d dbname --dir path
-h (host): MongoDB所在服务器地址,默认为: localhost:27017
-d (db): 需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如test2
--dir: 指定备份的目录
网友评论