版本:mongodb3.4 ;

分片:

  工作顺序:router=>config=>shards

 一,配置config:

   3.4中config必须为replSet。下面配置两个config。

   mongod --configsvr -dbpath= ..   -logpath=..   replSet=myConfig -port=3001 --fork;

     mongod --configsvr -dbpath=..    -logpaht=..  replSet=myConfig  -port=3002 --fork;

   进入config,mongo --port 3001,配置副本集:

   var config={

      _id:'myConfig',

       configsvr:true,

       memeber:[{_id:0,host:155.155.1.104:3001},   {_id:0,host:155.155.1.104:3002}]

    }

    rs.initiate(config);

    官方建议三个,我们这里只有两个。host,不能为127.0.0.1,或者localhost。所以我配置为局域网的地址了。

二,配置shard:

   mongod --shardsvr dbpath=.. -logpath=.. -port=4001 -nojournal --fork

   mongod --shardsvr dbpath=..  -logpath=.. -port=4002 -nojournal --fork

  生存环境下建议shard为replSet,这里姑且就为mongod吧

三,配置router:

  mongos -configdb=myConfig/155.155.1.104:3001,155.155.1.104:3002 -port=3000

  将config副本集写进去

四,定义shard:

  进入mongos :

         mongo -host=155.155.1.104  -port=3000

  use admin;

  添加分片:

      sh.addShard( '155.155.1.104:4001');   sh.addShard('155.155.1.104:4002');

  激活一个db:

      sh.enableSharding('test');

  为该db中的collection添加规则:

      sh.shardCollection('test.collection1',{_id:'hashed'})

 

文档连接:

文档引用

  官方使用的方法,将一个document 的field指向另一个document的_id。

树形结构:

  子定义一个parent。父定义一个children。将子父的一个filed放入其中。可以建立索引。更遥远的可以定义ancestor。

树形路径:

  定义document的一个filed为string型  ',path,path1,path2'。根据树形结构,写放路径。

二叉树路径:

  每个document,拥有一个left,right为number型。根据left,right和二叉树结构,可以遍历其子document。

数据引用:

  将document的一个filed定义为DBRef,其结构如下:

        creator:{

         $ref:  //指向collection;                        =》namespace  //在node.js中获得DBRef时,所对应的属性。

          $db:  //指向db;                                =》db

          $id: //指向collection.document._id; =》 oid

        }

mongodb does not support joins。

介绍下mongoose population:

  连接两个文档,并通过父文档find子文档的属性:

var parentSchema=new Schema({
name:String,
children:{type:Schema.Types.ObjectId, ref:'children'}
})
var childSchema=new Schema({
name:String
}) // 在父schema中定义children,指向子document的_id,使用ref指向该collection。
//下面是创建这两个document,分别在parent和children这两个collection中。 var parentModel=mongoose.model('parent',parentSchema);
var childrenModel=mongoose.model('children',childSchema); var childOne=new ChildrenModel({ name : ' B' });
childOne.save(val=>{
(new parentModel({
name:' A',
children:childOne._id
})) .save();
}) //这样就将两个document分别写入其各自的collection 中了。
//下面是使用他们; parentModel.findOne({name:'A'}).populate('children') //populate 中的值为parentSchema的children属性.
.exec((err,doc)=>{
console.log(doc.children.name); //show 'B'
})

  update

parentModel.findOne({name:'A'}).populate('children')
.exec((err,doc)=>{
doc.children= ...; //重新指定一个document。可以是document._id。也可以直接传递document
doc.save(callback);
})

  很遗憾的是不能通过doc.children.name='';doc.save();这种方式来更改children document内的属性。

动态连接:

var parentSchem=new Schema({
name:String,
children:[ {
kind:String,
item:{type:ObjectId , refPath: 'children.kind '} } ]
}) //refPath指向children.kind。通过kind的值,来定义类似之前ref的值;
//使用: parentMode.findOne({name:'A'}).populate('children.item').exec()

  ref的值是不能直接更改的。所以通过更改kind的值,可以更改连接的子文档。

 

mongodb笔记(一) 分片 &&文档连接的更多相关文章

  1. MongoDB改动、删除文档的域属性实例

    MongoDB改动.删除文档的域属性实例 在站点的开发中,可能最初的设计不合理.或者后期业务的变更,会造成文档结构会有些无用的属性.须要去删除或改动.因为MongoDB 是无 Schema 的,不像关 ...

  2. MongoDB,无模式文档型数据库简介

    MongoDB的名字源自一个形容词humongous(巨大无比的),在向上扩展和快速处理大数据量方面,它会损失一些精度,在旧金山举行的MondoDB大会上,Merriman说:“你不适宜用它来处理复杂 ...

  3. mongodb查询内嵌文档

    mongodb查询内嵌文档   假设有这样一个文档: db.XXX.remove(); db.XXX.insert({"id":1, "members":[{& ...

  4. Spring Data MongoDB 四:基本文档改动(update)(一)

    Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 二:MongoDB加入.删除.改动 一.简单介绍 Spring Data  Mo ...

  5. Spring Data MongoDB 五:进阶文档查询(分页、Morphia)(二)

    Spring Data MongoDB 三:基本文档查询(Query.BasicQuery)(一) 学习MongoDB 六: MongoDB查询(游标操作.游标信息)(三) 一.简单介绍 Spring ...

  6. MongoDB和Redis-NoSQL数据库-文档型-内存型

    1NoSQL简述 CAP(Consistency,Availabiity,Partitiontolerance)理论告诉我们,一个分布式系统不可能满足一致性,可用性和分区容错性这三个需求,最多只能同时 ...

  7. Mongodb 笔记07 分片、配置分片、选择片键、分片管理

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

  8. MongoDB学习(查找文档和其他数据查找操作)

    理解Cursor对象和查询运算符 cursor对象 cursor对象相当于一个指针,可通过迭代它来访问MongdoDB数据库中的一组对象. 在使用 find() 方法查询时,返回的并非实际文档,而是一 ...

  9. Spring Data MongoDB 三:基本文档查询(Query、BasicQuery)(一)

    一.简单介绍 Spring Data  MongoDB提供了org.springframework.data.mongodb.core.MongoTemplate对MongoDB的CRUD的操作,上一 ...

随机推荐

  1. curl post CURLOPT_POSTFIELDS

    PHP: curl_setopt - Manual http://php.net/manual/en/function.curl-setopt.php CURLOPT_POST TRUE to do ...

  2. client-side internet transfers

    curl https://curl.haxx.se/ curl - Open Collective https://opencollective.com/curl#backers curl/curl: ...

  3. 模块 - hashlib/subprocess

    hashlib 模块 加密算法: hash (152位)散列 哈希 不可逆得 密码背后就是 hash 程序退出hash 值就变了 ,hash值得结果有可能重复 MD5 (128位) 讯息摘要演算法 基 ...

  4. Linux(2)- linux目录结构、shell基本命令

    一.Linux之文档与目录结构 1.Linux文件系统结构 Linux目录结构的组织形式和Windows有很大的不同.Linux没有“盘(如C盘.D盘.E盘)”的概念,而是建立一个根"/&q ...

  5. Andrew Ng机器学习编程作业:Multi-class Classification and Neural Networks

    作业文件 machine-learning-ex3 1. 多类分类(Multi-class Classification) 在这一部分练习,我们将会使用逻辑回归和神经网络两种方法来识别手写体数字0到9 ...

  6. cmd命令行和bat批处理操作windows服务(转载)

    一.cmd命令行---进行Windows服务操作 1.安装服务 sc create 服务名 binPath= "C:\Users\Administrator\Desktop\win32srv ...

  7. java多线程总结(一)

    在java中要想实现多线程,有两种手段,一种是继续Thread类,另外一种是实现Runable接口. 对于直接继承Thread的类来说,代码大致框架是: 1 2 3 4 5 6 7 8 9 10 11 ...

  8. PolyBase--整合SQLServer和Hadoop

    我们一直强调,大数据和传统的关系数据库并不对立,未来公司的的业务将会是大数据和关系型数据库的整合.微软的PolyBase打响了SQL Server和Hadoop整合的第一枪. 在2012年度的SQL ...

  9. redis 笔记04 服务器、复制

    服务器 1. 一个命令请求从发送到完成主要包括以下步骤: 1). 客户端将命令请求发送给服务器 2). 服务器读取命令请求,并分析出命令参数 3). 命令执行器根据参数查找命令的实现函数,然后执行实现 ...

  10. Javascript Array对象 sort()方法,记忆方法,方法扩展

    相信 有很多 同仁们,尤其是初学者,在记住 Array对象 sort() 方法的排序,规则上,有点困难: 其实sort()方法已经在实际工作中用到很多遍了,可当我仔细推敲,这个sort()方法,什么时 ...