MongoDB笔记

概述

这里写图片描述
这里写图片描述
这里写图片描述
小技巧:手动创建一个后缀为bat的文件,文件名任意,内容为: mongod –dbpath=D:\mongo_data,双击此文件就可以启动MongoDB服务,不用每次都到命令行执行启动命令
在启动服务器的shell下可以键入Ctrl-C来完全的停止mongod的运行

还可以使用命令将mongodb作为服务进行安装:
D:\mongodb\bin\mongod.exe –logpath D:\mongo_log\mongodb.log –logappend –dbpath D:\mongo_data –directoryperdb –serviceName MongoDB –install
从系统服务中移除此服务:
D:\mongodb\bin\mongod.exe –logpath D:\mongo_log\mongodb.log –logappend –dbpath D:\mongo_data –directoryperdb –serviceName MongoDB –remove

端口默认27017


常用命令

调用命令

db.help()

如果没写()则直接显示方法体
这里写图片描述

use

use mydb

这里写图片描述

创建与查询库

这里写图片描述
这里写图片描述
这里写图片描述
删除集合使用命令:db.集合名称.drop()

这里写图片描述
可以使用下面的循环语句批量插入多个文档

for(var i=0;i<1000;i++){
    db.customer.insert({name:”name”+i ,age:i});
}

还可以使用db.集合名称.save({})向集合中添加文档,save于insert不同之处为:使用insert如果插入的文档中_id已经存在,则不能插入,类似于关系型数据库中的主键冲突
save方法如果插入的文档中_id已经存在,则执行更新

这里写图片描述

  • 查询集合中的文档,可以使用命令 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});
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相反
    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述

更新

这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述
这里写图片描述


索引

这里写图片描述
explain是非常有用的工具,会帮助你获得查询方面诸多有用的信息。只要对游标调用该方法,就可以得到查询细节。explain会返回一个文档,而不是游标本身。如:

db.test.find().explain()
{
    "cursor" : "BasicCursor",
    "nscanned" : 1,
    "nscannedObjects" : 1,
    "n" : 1,
    "millis" : 0,
    "nYields" : 0,
    "nChunkSkips" : 0,
    "isMultiKey" : false,
    "indexOnly" : false,
    "indexBounds" : {
    } 
}

explain会返回查询使用的索引情况,耗时和扫描文档数的统计信息。

  • “cursor”:”BasicCursor”表示没有使用索引。
  • “nscanned”:1 表示查询了多少个文档。
  • “n”:1 表示返回的文档数量。
  • “millis”:0 表示整个查询的耗时。
    这里写图片描述

固定集合(capped collection)

固定集合指的是事先创建而且大小固定的集合 。

固定集合特性:固定集合很像环形队列,如果空间不足,最早的文档就会被删除,为新的文档腾出空间。一般来说,固定集合适用于任何想要自动淘汰过期属性的场景,没有太多的操作限制。

创建固定集合使用命令:

db.createCollection(“collectionName”,{capped:true,size:100000,max:100});  

size指定集合大小,单位为KB,max指定文档的数量

当指定文档数量上限时,必须同时指定大小。淘汰机制只有在容量还没有满时才会依据文档数量来工作。要是容量满了,淘汰机制会依据容量来工作。

//将普通集合转换为固定集合 :
db.runCommand({
    convertToCapped:“collectionName",
    size:10000,max:100
}); 

备份和恢复

这里写图片描述
这里写图片描述


导入(mongoimport)和导出(mongoexport)

这里写图片描述
这里写图片描述


安全和认证

每个MongoDB实例中的数据库都可以有许多用户。如果开启了安全性检查,则只有数据库认证用户才能执行读或者写操作。

在认证的上下文中,MongoDB会将普通的数据作为admin数据库处理。admin数据库中的用户被视为超级用户(即管理员)。

在认证之后,管理员可以读写所有数据库,执行特定的管理命令,如listDatabases和shutdown。

在开启安全检查之前,一定要至少有一个管理员账号。
这里写图片描述


主从复制(主从集群 )

主从复制是MongoDB最常用的复制方式。这种方式非常灵活,可用于备份、故障恢复、读扩展等。

最基本的设置方式就是建立一个主节点和一个或者多个从节点,每个从节点要知道主节点的地址。运行mongod –master就启动了主服务器。运行mongod –slave –source master_address 则启动了从服务器,其中master_address就是上面主节点的地址。
这里写图片描述
MongoDB的复制至少需要两个服务器或者节点。其中一个是主节点,负责处理客户端请求,其它的都是从节点,负责映射主节点的数据。

主节点记录在其上执行的所有操作。从节点定期轮询主节点获得这些操作,然后对自己的数据副本执行这些操作。由于和主节点执行了相同的操作,从节点就能保持与主节点的数据同步。

主节点的操作记录成为oplog(operation log)。oplog存储在一个特殊的数据库中,叫做local。oplog就在其中的oplog.$main集合里面。oplog中的每个文档都代表主节点上执行的一个操作。

需要重点强调的是oplog只记录改变数据库状态的操作。比如,查询就不再存储在oplog中。这是因为oplog只是作为从节点与主节点保持数据同步的机制。
这里写图片描述
这里写图片描述
注意:主节点可以进行增删改查所有操作,而从节点只能进行查询的操作


副本集

这里写图片描述
这里写图片描述
这里写图片描述
初始化节点(只能初始化一次):随便登录一个节点,以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
            }
]}});

参数解释:

  • –replSet 指定副本集 后面紧跟着副本集的名称
  • –logappend 日志文件末尾添加
  • –port 指定端口号

db.runCommand({}) 初始化副本集

初始化文档:

  • “_id”:“itcast”, 指副本集的名称
  • “members”:[…] 副本集的服务器列表 每个列表有个
    • ”_id”: 每个服务器的唯一id,
    • “host” 指定服务器的主机,
    • “priority”设置优先级,默认优先级为1,可以是1-1000的数字

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

关闭10001服务Dos命令窗口, 登录10002查询当前主库
mongo localhost:10002
db.$cmd.findOne ( {ismaster: 1 } );
这里写图片描述
默认情况下从库是不能进行读写操作的
设置从库可读(在从库secondary上执行):
rs.slaveOk ( );


分片(sharding)

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

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

设置分片时,需要从集合里面选一个键,用该键的值作为数据拆分的依据。这个键称为片键(shard key)。

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

  • mongos就是一个路由服务器,它会根据管理员设置的“片键”将数据分摊到自己管理的mongod集群,数据和片的对应关系以及相应的配置信息保存在“config服务器”上。
  • mongod:一个普通的数据库实例,如果不分片的话,我们会直接连上mongod。
    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述
    这里写图片描述

增删改查java实现

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();
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值