MongoDB基本介绍

MongoDB基本介绍

  • 文档(document)是MongoDB中数据的基本单元,非常类似于关系型数据库系统中的行(但是比行要复杂的多)
  • 集合(collection)就是一组文档,如果说MongoDB中的文档类似于关系型数据库中的行,那么集合就如同表
  • MongoDB的单个计算机可以容纳多个独立的数据库,每一个数据库都有自己的集合和权限
  • MongoDB自带简洁但功能强大的JavaScript shell,这个工具对于管理MongoDB实例和操作数据作用非常大
  • 每一个文档都有一个特殊的键”_id”,它在文档所处的集合中是唯一的,相当于关系数据库中的表的主键

MongoDB数据类型

Markdown Extra 表格语法:

数据类型描述举例
null表示空值或者未定义的对象{“x”:null}
布尔值真或者假:true或者false{“x”:true}
32位整数32位整数。shell是不支持该类型的,shell中默认会转换成64位浮点数
64位整数64位整数。shell是不支持该类型的,shell中默认会转换成64位浮点数
64位浮点数64位浮点数。shell中的数字就是这一种类型{“x”:3.14,”y”:3}
字符串UTF-8字符串{“foo”:”bar”}
符号shell不支持,shell会将数据库中的符号类型的数据自动转换成字符串
对象id文档的12字节的唯一id{“id”: ObjectId()}
日期从标准纪元开始的毫秒数{“date”:new Date()}
正则表达式文档中可以包含正则表达式,遵循JavaScript的语法{“foo”:/foobar/i}
代码文档中可以包含JavaScript代码{“x”:function() {}}
未定义undefined{“x”:undefined}
数组值的集合或者列表{“arr”: [“a”,”b”]}
内嵌文档文档可以作为文档中某个key的value{“x”:{“foo”:”bar”}}

安装MongoDB

MongoDB的安装非常简单,只需要将下载的MongoDB的压缩文件解压到任意目录,并将其中的bin目录加入到系统的path环境变量中即可。


启动MongoDB

在启动MongoDB之前,要手动创建一个存放MongoDB数据文件的目录,如D:\mongo_data
在命令行执行 mongod –dbpath=D:\mongo_data


连接到MongoDB服务器

在命令行中可以使用mongo命令连接到MongoDB服务器,如下,输入mongo命令默认连接到本地的名称为test的数据库,如果希望连接到远程数据库,可以使用mongo ip:port


MongoDB常用操作

  • 创建数据库,使用命令 use 数据库名称 ,如:use mydb1
  • 查看所有数据库,使用命令 show dbs
  • 查看当前所在数据库,使用命令 db
  • 查看当前数据库中所有的集合,使用命令 show collections 或使用show tables
  • 创建集合有两种方式,显示创建和隐式创建
    显示创建可以使用命令 db.createCollection(“集合名称”)
    隐式创建可以使用命令 db.集合名称.insert({}),指创建集合并同时向集合中插入数据,例如:db.customer.insert({name:”jack”})
  • 向集合添加文档,使用命令 db.集合名称.insert({}),例如:
    db.user1.insert({name:”jack”,age:20}
  • 删除集合中的文档,使用命令 db.集合名称.remove({删除条件}),不加删除条件为删除集合中的所有文档,例如,db.c1.remove() 为删除c1集合中的所有文档,db.c1.remove({name:”user1”})为删除c1集合中name为user1的文档
  • 查询集合中的文档,可以使用命令 db.集合名称.find({条件}),或者使用 db.集合名称.findOne() 查询第一个文档
  • 查询集合中的文档 ,使用条件表达式(<, <=, >, >=,!=)
//大于: field > value
db.collection.find({field:{$gt:value}});

//小于: field < value
db.collection.find({field:{$lt:value}});

//大于等于: field >= value
db.collection.find({field:{$gte:value}});

//小于等于: field <= value
db.collection.find({field:{$lte:value}});

//不等于:  field != value
db.collection.find({field:{$ne:value}});
  • 查询集合中的文档 ,统计(count)、排序(sort)、分页(skip、limit)
db.customer.count();
db.customer.find().count();
db.customer.find({age:{$lt:5}}).count();
db.customer.find().sort({age:1}); 降序-1
db.customer.find().skip(2).limit(3);
db.customer.find().sort({age:-1}).skip(2).limit(3);
db.customer.find().sort({age:-1}).skip(2).limit(3).count();
db.customer.find().sort({age:-1}).skip(2).limit(3).count(0);
db.customer.find().sort({age:-1}).skip(2).limit(3).count(1);
  • 查询集合中的文档 ,$all主要用来查询数组中的包含关系,查询条件中只要有一个不包含就不返回
  • 查询集合中的文档 ,$in,类似于关系型数据库中的IN
  • 查询集合中的文档 ,$nin,与in相反
  • 查询集合中的文档,$or,相当于关系型数据库中的OR,表示或者的关系,例如查询name为user2或者age为3的文档,命令为:db.customer.find({$or:[{name:”user2”},{age:3}]})
  • 查询集合中的文档 ,$nor,表示根据条件过滤掉某些数据,例如查询name不是user2,age不是3的文档,命令为:db.customer.find({$nor:[{name:”user2”},{age:3}]})
  • 查询集合中的文档 ,$exists,用于查询集合中存在某个键的文档或不存在某个键的文档,例如查询customer集合中存在name键的所有文档,可以使用

    db.customer.find({name:{$exists:1}})

exists:1表示真,指存在
exists:0表示假,指不存在
这里写图片描述

  • 查询集合中的文档 ,类似于关系型数据库,mongodb中也有游标的概念

这里写图片描述

  • 更新集合中的文档,语法如下:
    db.collection.update(criteria,objNew,upsert,multi)

参数说明:
criteria:用于设置查询条件的对象
objNew:用于设置更新内容的对象
upsert:如果记录已经存在,更新它,否则新增一个记录,取值为0或1
multi:如果有多个符合条件的记录,是否全部更新,取值为0或1

注意:默认情况下,只会更新第一个符合条件的记录
一般情况下后两个参数分别为0,1 ,即:
db.collection.update(criteria,objNew,0,1)

  • 更新集合中的文档, $set 用来指定一个键的值,如果这个键不存在,则创建它。例如:
    给name为user1的文档添加address,可以使用命令:
    db.c1.update({name:”user1”},{$set:{address:”bj”}},0,1)
    将name为user1的文档修改address为tj,其它键值对不变,命令为:
    db.c1.update({name:”user1”},{$set:{address:”tj”}},0,1)
  • 更新集合中的文档,使用 incnameuser1age1, inc表示使某个键值加减指定的数值
    这里写图片描述

  • 更新集合中的文档, $unset 用来删除某个键,例如删除name为user1的文档中的address键,可以使用命令:

db.c1.update({name:”user1”},{$unset:{address:1}},0,1)

索引

索引就是用来加速查询的。数据库索引与书籍的索引类似:有了索引就不需要翻遍整本书,数据库则可以直接在索引中查找,使得查找速度能提高几个数量级。在索引中找到条目以后,就可以直接跳转到目标文档的位置。


  • 创建普通索引,使用命令 db.collection.ensureIndex({key:1})
  • 查看关于索引的相关信息,使用命令 db.collection.stats()
  • 查看查询使用索引的情况,使用命令 db.collection.find({key:value}).explain()
  • 删除索引,使用命令 db.collection.dropIndex({key:1})
  • 删除集合,也会将集合中的索引全部删除
  • 创建唯一索引,使用命令 db.collection.ensureIndex({key:1},{unique:true})
  • 查看关于索引的相关信息,使用命令 db.collection.stats()
  • 查看查询使用索引的情况,使用命令 db.collection.find({key:value}).explain()
  • 删除索引,使用命令 db.collection.dropIndex({key:1})
  • 删除集合,也会将集合中的索引全部删除

固定集合(capped collection)

固定集合指的是事先创建而且大小固定的集合 。
固定集合特性:固定集合很像环形队列,如果空间不足,最早的文档就会被删除,为新的文档腾出空间。一般来说,固定集合适用于任何想要自动淘汰过期属性的场景,没有太多的操作限制。
创建固定集合使用命令:db.createCollection(“collectionName”,{capped:true,size:100000,max:100});
size指定集合大小,单位为KB,max指定文档的数量
当指定文档数量上限时,必须同时指定大小。淘汰机制只有在容量还没有满时才会依据文档数量来工作。要是容量满了,淘汰机制会依据容量来工作。

备份(mongodump)和恢复(mongorestore)

MongoDB提供了备份和恢复的功能,分别是MongoDB下载目录下的mongodump.exe和mongorestore.exe文件
备份数据使用下面的命令:>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目录,这个目录里面存放该数据库实例的备份数据。

恢复数据使用下面的命令:>mongorestore -h dbhost -d dbname -directoryperdb dbdirectory

-h:MongoDB所在服务器地址
-d:需要恢复的数据库实例,例如:test,当然这个名称也可以和备份时候的不一样,比如test2
-directoryperdb:备份数据所在位置,例如:c:\data\dump\test


导入(mongoimport)和导出(mongoexport)

导出数据可以使用命令:

mongoexport -h dbhost -d dbname -c collectionName -o output

参数说明:
-h 数据库地址
-d 指明使用的库
-c 指明要导出的集合
-o 指明要导出的文件名

导入数据可以使用命令:

mongoimport -h dbhost -d dbname -c collectionname 文件的地址...

参数说明:
-h 数据库地址
-d 指明使用的库
-c 指明要导入的集合
本地的文件地址…


安全和认证

每个MongoDB实例中的数据库都可以有许多用户。如果开启了安全性检查,则只有数据库认证用户才能执行读或者写操作。
在认证的上下文中,MongoDB会将普通的数据作为admin数据库处理。admin数据库中的用户被视为超级用户(即管理员)。
在认证之后,管理员可以读写所有数据库,执行特定的管理命令,如listDatabases和shutdown。
在开启安全检查之前,一定要至少有一个管理员账号。

在admin数据库中创建管理员账号:
use admin;
db.addUser(“root”,”root”);

在test数据库中创建普通账号:
use test;
db.addUser(“zhangsan”,”123”);
db.addUser(“lisi”,”123”,true);
注意:用户zhangsan,密码为123,对test数据库拥有读写权限
用户lisi,密码为123,对test数据库拥有只读权限

重新启动数据库服务,并开启安全检查:
mongod –dbpath d:\mongo_data –auth

主从复制(主从集群 )

主从复制是MongoDB最常用的复制方式。这种方式非常灵活,可用于备份、故障恢复、读扩展等。
最基本的设置方式就是建立一个主节点和一个或者多个从节点,每个从节点要知道主节点的地址。运行mongod –master就启动了主服务器。运行mongod –slave –source master_address 则启动了从服务器,其中master_address就是上面主节点的地址。

这里写图片描述

为了方便测试,可以在一台计算机上来模拟主节点和从节点。在D盘创建两个目录master和slave,master目录作为主节点的数据文件的目录,slave目录作为从节点的数据文件的目录。
注意:主节点和从节点要指定不同的端口。
启动主节点:mongod –dbpath d:\master –port 10000 –master
启动从节点:mongod –dbpath d:\slave –port 10001 –slave –source localhost:10000

启动成功后就可以连接主节点进行操作了,而这些操作会同步到从节点。

副本集

副本集就是有自动故障恢复功能的主从集群。

主从集群和副本集最大的区别就是副本集没有固定的“主节点”;整个集群会选出一个“主节点”,当其挂掉后,又在剩下的从节点中选中其他节点为“主节点”,副本集总有一个活跃点(primary)和一个或多个备份节点(secondary)。

以三个节点为例:
节点1:
HOST:localhost:10001
Log File:D:\mongodb\logs\node1\logs.txt
Data File:D:\mongodb\dbs\node1

节点2:
HOST:localhost:10002
Log File:D:\mongodb\logs\node2\logs.txt
Data File:D:\mongodb\dbs\node2

节点3:
HOST:localhost:10003
Log File:D:\mongodb\logs\node3\logs.txt
Data File:D:\mongodb\dbs\node3

启动节点1:
mongod –dbpath D:\mongodb\dbs\node1 –logpath D:\mongodb\logs\node1\logs.txt –logappend –port 10001 –replSet itcast/localhost:10002 –master

启动节点2:
mongod –dbpath D:\mongodb\dbs\node2 –logpath D:\mongodb\logs\node2\logs.txt –logappend –port 10002 –replSet itcast/localhost:10001

启动节点3:
mongod –dbpath D:\mongodb\dbs\node3 –logpath D:\mongodb\logs\node3\logs.txt –logappend –port 10003 –replSet itcast/localhost:10001,localhost:10002

初始化节点(只能初始化一次):随便登录一个节点,以10001为例
mongo localhost:10001/admin
db.runCommand({ “replSetInitiate”:{ “_id”:“itcast”, “members”:[ { “_id”:1, “host”:”localhost:10001”, “priority”:3 }, { “_id”:2, “host”:”localhost:10002”, “priority”:2 }, { “_id”:3, “host”:”localhost:10003”, “priority”:1 } ]}});

查询当前主库,登录10002
mongo localhost:10002
db.$cmd.findOne ( {ismaster: 1 } );
这里写图片描述

关闭10001服务Dos命令窗口, 登录10002查询当前主库
mongo localhost:10002
db.$cmd.findOne ( {ismaster: 1 } );

这里写图片描述

分片(sharding)分布式存储..

分片(sharding)是指将数据拆分,将其分散存在不同的机器上的过程。有时也用分区(partitioning)来表示这个概念。将数据分散到不同的机器上,不需要功能强大的大型计算机就可以储存更多的数据,处理更多的负载。

MongoDB分片的基本思想就是将集合切分成小块。这些块分散到若干片里面,每个片只负责总数据的一部分。应用程序不必知道哪片对应哪些数据,甚至不需要知道数据已经被拆分了,所以在分片之前要运行一个路由进程,该进程名为mongos。这个路由器知道所有数据的存放位置,所以应用可以连接它来正常发送请求。对应用来说,它仅知道连接了一个普通的mongod。路由器知道数据和片的对应关系,能够转发请求到正确的片上。如果请求有了回应,路由器将其收集起来回送给应用。

设置分片时,需要从集合里面选一个键,用该键的值作为数据拆分的依据。这个键称为片键(shard key)。
{name:”zhangsan”,age:1}
用个例子来说明这个过程:假设有个文档集合表示的是人员。如果选择名字(“name”)作为片键,第一片可能会存放名字以A~F开头的文档,第二片存的G~P的名字,第三片存的Q~Z的名字。随着添加或者删除片,MongoDB会重新平衡数据,使每片的流量都比较均衡,数据量也在合理范围内。
这里写图片描述

使用java操作MongoDB

1、查询集合中所有文档

Mongo mongo = new Mongo("localhost",27017);
DB db = mongo.getDB("test");
DBCollection collection = db.getCollection("customer");
DBCursor dbCursor = collection.find();
System.out.println(collection.getCount());
while(dbCursor.hasNext()){
System.out.println(dbCursor.next());
}
mongo.close();

2、删除集合中的文档

Mongo mongo = new Mongo("localhost",27017);
DB db = mongo.getDB("test");
DBCollection collection = db.getCollection("customer");
BasicDBObject o = new BasicDBObject("_id", new ObjectId("5199ee647d5fc789bc760c07"));
collection.remove(o);
mongo.close();

3、向集合中插入文档

Mongo mongo = new Mongo("localhost",27017);
DB db = mongo.getDB("test");
DBCollection collection = db.getCollection("customer");
DBObject c = new BasicDBObject();
c.put("name", “jack");
c.put("age", 24);
collection.insert(c);
mongo.close();

4、更新集合中的文档

Mongo mongo = new Mongo("localhost",27017);
DB db = mongo.getDB("test");
DBCollection collection = db.getCollection("customer");
BasicDBObject query = new BasicDBObject("_id",new ObjectId("519e2e393296cf3baccdb10c"));
BasicDBObject object = (BasicDBObject) collection.findOne(query);
object.put("name", “wangwu");
int n = collection.update(query, object).getN();
System.out.println(n);
mongo.close();
MongoDB是一个开源的、面向文档的NoSQL数据库管理系统。它以高性能、高可扩展性和灵活性而闻名。以下是MongoDB介绍: 1. MongoDB概述:MongoDB是一个基于分布式文件存储的数据库系统,它将数据存储为文档,使用类似于JSON的格式。它是一个非关系型数据库,不需要预定义模式,可以动态地添加字段。 2. MongoDB特性:MongoDB具有许多特性,包括高性能、高可用性、自动分片、灵活的数据模型、强大的查询语言、支持地理空间索引等。 3. MongoDB的元素:MongoDB基本元素是文档,文档是一组键值对的集合,类似于关系数据库中的行。文档可以嵌套,可以包含数组和其他文档。 4. MongoDB支持语言:MongoDB提供了多种编程语言的驱动程序,包括Python、Java、C#等。这使得开发人员可以使用自己喜欢的编程语言与MongoDB进行交互。 5. MongoDB的“ObjectId”:MongoDB使用ObjectId作为文档的唯一标识符。ObjectId是一个12字节的唯一标识符,由时间戳、机器标识符、进程ID和随机数组成。 6. MongoDB数据类型:MongoDB支持多种数据类型,包括字符串、整数、浮点数、布尔值、日期、正则表达式、数组、嵌套文档等。 7. MongoDB与关系数据库基本概念比较:MongoDB与传统的关系数据库有一些不同之处,例如没有表和行的概念,没有预定义的模式等。这使得MongoDB更加灵活和易于扩展。 你可以在菜鸟教程的MongoDB教程中了解更多关于MongoDB的信息:[菜鸟教程链接](https://www.runoob.com/mongodb/mongodb-tutorial.html)。 你也可以在MongoDB官网上找到更多关于MongoDB的详细信息:[官网链接](https://www.mongodb.com/)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值