介绍:MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
1、MongoDB特点
高性能、易部署、易使用,存储数据非常方便。
主要功能特性有:
面向集合存储,易存储对象类型的数据
模式自由
支持动态查询
支持完全索引,包含内部对象
支持查询
支持复制和故障恢复
使用高效的二进制数据存储,包括大型对象(如视频等)
自动处理碎片,以支持云计算层次的扩展性
支持RUBY,PYTHON,JAVA,C++,PHP等多种语言
文件存储格式为BSON(一种JSON的扩展)
可通过网络访问
2、MonogDB原理
所谓“面向集合”(Collenction-Oriented),意思是数据被分组存储在数据集中,被称为一个集合(Collenction)。每个集合在数据库中都有一个唯一的标识名,并且可以包含无限数目的文档。集合的概念类似关系型数据库(RDBMS)里的表(table),不同的是它不需要定义任何模式(schema)。
模式自由(schema-free),意味着对于存储在mongodb数据库中的文件,我们不需要知道它的任何结构定义。如果需要的话,你完全可以把不同结构的文件存储在同一个数据库里。
存储在集合中的文档,被存储为键-值对的形式。键用于唯一标识一个文档,为字符串类型,而值则可以是各种复杂的文件类型。我们称这种存储形式为BSON(Binary JSON)。
3、MongoDB的启动
在安装了windows服务后,可是使用net start MongoDBNew命令来启动,其中MongoDBNew为我们注册的服务名
4、MongoDB的简单操作
在MongoDB安装目录的bin目录命令行下,输入mongo,打开MongoDB的shell命令行,这是一个JavaScript Shell,js也可以在这里使用,也即MongoDB的客户端,默认连接test数据库
(1)插入insert
在有了数据库之后,下一步就是集合,即表,我们创建一个集合为students,文档时JSON的一个扩展即Bson(Binary JSON)
> db.students.insert({"name":"niww","age":18,"sex":"b"})
> db.students.insert({"name":"jess","age":18,"sex":"g"})
(2)修改update
> db.students.update({"name":"Lilei"},{"name":"Lilei","age":40})
其中,第一个参数为“查找的条件”,第二个参数为“更新的值”
注意:在更新时,要对所有字段进行更新,否则未更新字段将丢失信息
(3)查询
在数据插入数据库后,需要通过查询操作来显示数据
> db.students.find()
{ "_id" : ObjectId("5168e0eb4839f16259ac8aad"), "name" : "niww", "age" : 18, "sex" : "b" }
{ "_id" : ObjectId("5168e0f54839f16259ac8aae"), "name" : "jess", "age" : 28 }
> db.students.update({"name":"jess"},{"name":"jess","age":28,"sex":"g"})
> db.students.find()
{ "_id" : ObjectId("5168e0eb4839f16259ac8aad"), "name" : "niww", "age" : 18, "sex" : "b" }
{ "_id" : ObjectId("5168e0f54839f16259ac8aae"), "name" : "jess", "age" : 28, "sex" : "g" }
> db.students.find({"name":"niww"})
{ "_id" : ObjectId("5168e0eb4839f16259ac8aad"), "name" : "niww", "age" : 18, "sex" : "b" }
>
(4)删除
> db.students.remove({"name":"jess"})
> db.students.find()
{ "_id" : ObjectId("5168e0eb4839f16259ac8aad"), "name" : "niww", "age" : 18, "sex" : "b" }
>
如果remove不带任何参数,则默认为删除集合中的所有数据