小白需要观摩的mongodb知识

Mongodb
MongoDB是一个基于分布式文件存储的数据库。由C++语言编写。旨在为WEB应用提供可扩展的高性能数据存储解决方案。
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是它支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。
介于关系数据库和非关系数据库之间的产品
基于分布式文件存储的数据库,旨在为web应用提供可扩展的高性能数据存储解决方案
将数据存储为一个文档,数据结构由键值对组成
支持丰富的查询表达,可以设置任何属性的索引
支持副本集(集群),分片。

特点编辑
它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有:
*面向集合存储,易存储对象类型的数据。
mongodb集群参考
mongodb集群参考
*模式自由。
*支持动态查询。
*支持完全索引,包含内部对象。
*支持查询。
*支持复制和故障恢复。
*使用高效的二进制数据存储,包括大型对象(如视频等)。
*自动处理碎片,以支持云计算层次的扩展性。
*支持RUBY,PYTHON,JAVA,C++,PHP,C#等多种语言。
*文件存储格式为BSON(一种JSON的扩展)。
*可通过网络访问。
使用原理编辑
所谓“面向集合”(Collection-Oriented),意思是数据被分组存储在数据集中,被称为一个集合(Collection)。每个集合在数据库中都有一个唯一的标识名,并且可以包含无限数目的文档。集合的概念类似关系型数据库(RDBMS)里的表(table),不同的是它不需要定义任何模式(schema)。Nytro MegaRAID技术中的闪存高速缓存算法,能够快速识别数据库内大数据集中的热数据,提供一致的性能改进。
模式自由(schema-free),意味着对于存储在mongodb数据库中的文件,我们不需要知道它的任何结构定义。如果需要的话,你完全可以把不同结构的文件存储在同一个数据库里。
存储在集合中的文档,被存储为键-值对的形式。键用于唯一标识一个文档,为字符串类型,而值则可以是各种复杂的文件类型。我们称这种存储形式为BSON(Binary Serialized Document Format)。
MongoDB已经在多个站点部署,其主要场景如下:
1)网站实时数据处理。它非常适合实时的插入、更新与查询,并具备网站实时数据存储所需的复制及高度伸缩性。
2)缓存。由于性能很高,它适合作为信息基础设施的缓存层。在系统重启之后,由它搭建的持久化缓存层可以避免下层的数据源过载。
3)高伸缩性的场景。非常适合由数十或数百台服务器组成的数据库,它的路线图中已经包含对MapReduce引擎的内置支持。
不适用的场景如下:
1)要求高度事务性的系统。
2)传统的商业智能应用。
3)复杂的跨文档(表)级联查询。
系统介绍编辑
分布式文件系统(Distributed File System)是指文件系统管理的物理存储资源不一定直接连接在本地节点上,而是通过计算机网络与节点相连。分布式文件系统的设计基于客户机/服务器模式。一个典型的网络可能包括多个供多用户访问的服务器。另外,对等特性允许一些系统扮演客户机和服务器的双重角色。
HBase是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的Google论文“Bigtable:一个结构化数据的分布式存储系统。
Yonghong Data Mart是基于自有技术研发的一款数据存储、数据处理的软件。Yonghong Data Mart的分布式文件存储系统 (ZDFS)是在Hadoop HDFS基础上进行的改造和扩展,将服务器集群内所有节点上存储的文件统一管理和存储。

区别:
mongodb mysql
集和collection---------》表table
文档document---------》行/记录row/record

配置:
无需安装 , 解包 在创个/usr/local/mongodb目录
在目录下创目录
./etc/mongodb.conf ./bin ./log /data/db

./etc/mongodb.conf
	logpath=             //日志文件地址
	dbpath=				//数据库目录地址
	logappend=true		//日志自动追加
	fork=true  			//开启守护进程
	bind_ip= 
	port=

use 库名 //切换库,若不存在。则延时创建。

基本数据类型
1 字符类型 是什么类型就是什么类型
db.t1.save({ name:“bob” , age:21 })

	2 布尔bool (真true  假 false)
db.t2.save({name:"tom",memry:false,card:true})

	3 空null
db.t2.save({name:"lucy",ruslt:null})

	4 数值		
	> db.t2.save({x:3003, y:3.23 })
	> db.t2.save({x:NumberInt(99.99)}) 只存储的 99
	> db.t2.save({x:NumberLong(88.77)}) 不允许写有小数的数

	5 数组array
	> db.t2.save({name:"bob" , likes:["hpop","papa","eat"]})

	6 代码
	> db.t2.save({ lname:"php" , phpcode:function(){/*<?php echo  "hello  boy!!!"; ?>*/} })

	7 日期
	> db.t2.save({name:"jack",birthday:"2019/11/20"})
	> db.t2.save({name:"jack2",birthday:new Date()})
	
	8 对象ObjectId() 
	> db.t2.save({
	... num:ObjectId(),name:"jack3",
	... age:19
	... })

	> 
	> db.t2.find({name:"jack3"})
	9 内嵌 

	>db.t2.save({ 
	tarena:{
	worker:"hsy",
	tel:119 , 
	address:"beijing", 
	peple:10000},money:10000
	})

	10 正则表达式	
	> db.t2.save({ linenull:/^$/ ,linefirst:/^/ })

2.3 数据导入与导出
2.3.1 导出:把集合里文档存储到系统文件里
命令格式:
csv ,

导出:
csv类型 (必须有 -f指定字段)
/usr/local/mongodb/bin/mongoexport --host 地址 --port 端口 -d 库 -c 集合 -q 正则 -f 字段 --type=csv > t2.txt
json类型
/usr/local/mongodb/bin/mongoexport --host 地址 --port 端口 -d 库 -c 集合【 -q 正则 -f 字段 】 --type=json > t2.txt

导入:
csv类型 (必须有 -f指定字段 或者 --headerline) --drop
/usr/local/mongodb/bin/mongoimport --host 地址 --port 端口 -d 库 -c 集合 -q 正则 -f 字段 --type=csv t2.txt
json类型
/usr/local/mongodb/bin/mongoimport --host 地址 --port 端口 -d 库 -c 集合 --type=json t2.txt

备份:
mongodump --host --port 默认备份整个数据库 到当前目录的dump下

mongodump   --host --port  -d 数据库  -c 集合   -o  自创目录

恢复:
mongorestore --host --port -d 数据库 [-c 集合名] 备份目录

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
疫情居家办公系统管理系统按照操作主体分为管理员和用户。管理员的功能包括办公设备管理、部门信息管理、字典管理、公告信息管理、请假信息管理、签到信息管理、留言管理、外出报备管理、薪资管理、用户管理、公司资料管理、管理员管理。用户的功能等。该系统采用了MySQL数据库,Java语言,Spring Boot框架等技术进行编程实现。 疫情居家办公系统管理系统可以提高疫情居家办公系统信息管理问题的解决效率,优化疫情居家办公系统信息处理流程,保证疫情居家办公系统信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理疫情居家办公系统信息,包括外出报备管理,培训管理,签到管理,薪资管理等,可以管理公告。 外出报备管理界面,管理员在外出报备管理界面中可以对界面中显示,可以对外出报备信息的外出报备状态进行查看,可以添加新的外出报备信息等。签到管理界面,管理员在签到管理界面中查看签到种类信息,签到描述信息,新增签到信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息
MongoDB是一个开源的、跨平台的、面向文档的NoSQL数据库管理系统。它以JSON风格的文档存储数据,具有灵活的数据模型和强大的查询能力。以下是一些MongoDB知识点: 1. 数据模型:MongoDB使用BSON(二进制JSON)格式存储数据,可以存储复杂的数据结构,如嵌套文档和数组。每个文档都有一个唯一的_id字段作为主键。 2. 集合和文档:MongoDB将数据组织成集合(Collection),每个集合包含多个文档(Document)。文档类似于关系数据库中的行,但没有固定的模式。 3. 查询:MongoDB支持丰富的查询语法,包括比较、逻辑、正则表达式等操作符。可以使用find()方法进行查询,并可以使用索引来提高查询性能。 4. 索引:MongoDB支持创建索引来加速查询。常见的索引类型包括单字段索引、复合索引、文本索引等。可以使用ensureIndex()方法创建索引。 5. 聚合管道:MongoDB提供了聚合管道(Aggregation Pipeline)功能,可以对集合中的文档进行多阶段的数据处理和转换。 6. 复制和故障转移:MongoDB支持数据复制和故障转移,通过复制集(Replica Set)来提供数据的冗余和高可用性。 7. 分片:MongoDB支持数据分片(Sharding),可以将数据分散存储在多个服务器上,提高数据存储和查询的性能。 8. 安全性:MongoDB提供了访问控制、身份验证和加密等安全功能,可以保护数据的机密性和完整性。 以上只是MongoDB的一些基本知识点,还有更多高级的功能和特性可以进一步学习和探索。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值