什么是MongoDB ?
MongoDB 是由C++语言编写的,是一个基于分布式文件存储的开源数据库系统。
在高负载的情况下,添加更多的节点,可以保证服务器性能。
MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB 将数据存储为一个文档,数据结构由键值(key=>value)对组成。MongoDB 文档类似于 JSON 对象。字段值可以包含其他文档,数组及文档数组。
image
主要特点
- MongoDB 是一个面向文档存储的数据库,操作起来比较简单和容易。
- 你可以在MongoDB记录中设置任何属性的索引 (如:FirstName="Sameer",Address="8 Gandhi Road")来实现更快的排序。
- 你可以通过本地或者网络创建数据镜像,这使得MongoDB有更强的扩展性。
- 如果负载的增加(需要更多的存储空间和更强的处理能力) ,它可以分布在计算机网络中的其他节点上这就是所谓的分片。
- Mongo支持丰富的查询表达式。查询指令使用JSON形式的标记,可轻易查询文档中内嵌的对象及数组。
- MongoDb 使用update()命令可以实现替换完成的文档(数据)或者一些指定的数据字段 。
- Mongodb中的Map/reduce主要是用来对数据进行批量处理和聚合操作。
- Map和Reduce。Map函数调用emit(key,value)遍历集合中所有的记录,将key与value传给Reduce函数进行处理。
- Map函数和Reduce函数是使用Javascript编写的,并可以通过db.runCommand或mapreduce命令来执行MapReduce操作。
- GridFS是MongoDB中的一个内置功能,可以用于存放大量小文件。
- MongoDB允许在服务端执行脚本,可以用Javascript编写某个函数,直接在服务端执行,也可以把函数的定义存储在服务端,下次直接调用即可。
- MongoDB支持各种编程语言:RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
- MongoDB安装简单。
简单命令
新增
//创建集合
db.createCollection('test_llm');
//删除集合
db.test_llm.drop()
//新增数据
db.test_llm.insert({title: 'MongoDB 教程',
description: 'MongoDB 是一个 Nosql 数据库',
by: '菜鸟教程',
url: 'http://www.runoob.com',
tags: ['mongodb', 'database', 'NoSQL'],
likes: 100
});
更新
// update 更新数据
db.test_llm.update({'by':'菜鸟教程'},{$set:{'by':'测试菜鸟教程更新'}});
// save 更新数据
db.test_llm.save({
"_id" : ObjectId("5d073e64b0b1733cd00641ca"),
"title" : "MongoDB",
"description" : "MongoDB 是一个 Nosql 数据库",
"by" : "Runoob",
"url" : "http://www.runoob.com",
"tags" : [
"mongodb",
"NoSQL"
],
"likes" : 110
});
删除
//删除数据
db.test_llm.remove({'title':'MongoDB 教程'})
查询
//查询所有 pretty() 方法以格式化的方式来显示所有文档。
db.address.find().pretty()
//返回一个
db.address.findOne({'address_id':'1'})
1560757681(1).jpg
MongoDB AND 条件
//and 条件
db.address.find({'address_id':'2','address_name':'金鱼池西街11中金鱼池校区二号楼二层201教室'}).pretty()
OR 条件
//or 条件
db.address.find({$or:[{'address_id':'2'},{'address_id':'9'}]})
AND 和 OR 联合使用
//AND 和 OR 联合使用
db.address.find({$or:[{'address_id':'2'},{'address_id':'9'}],'address_name':'北京市东城区外交部街31号北楼实验室207'})
网友评论