《MongoDB权威指南》epub下载在线阅读,求百度网盘云资源
《MongoDB权威指南》(霍多罗夫 (Kristina Chodorow))电子书网盘下载免费在线阅读
资源链接:
链接:https://panbaiducom/s/1CLFDmIN5ySf0lF4ciZVjHQ
提取码:p242书名:MongoDB权威指南
作者:霍多罗夫 (Kristina Chodorow)
出版社:东南大学出版社
出版年份:2014-1-1
页数:409
作者简介:
KristinaccChodorow
13310gen的软件工程师,2MongoDB项目的核心成员a负责数据库服务器、PHP驱动、Perl驱动等模块a她曾在世界级的大会上发言,2包括OSCON、LinuxCon、FOSDEM和Latinowarea
局域网内远程的话,首先被远程机要允许远程控制,具体设置为 右键我的电脑 远程 勾选允许用户远程联机到这部电脑,主控端电脑就需要 勾选 允许从这部电脑发送远程协助就可以了。
然后在主控端PC那运行 mstsc 弹出对话框,根据提示输入被控端的IP地址或者主机名就可以。
如果你的是要远程外地的电脑的话,也是一样需要知道外地电脑IP地址。但是很多情况下都是需要通过软件来弄或者是在路由里面设置。
远程控制是在网络上由一台电脑(主控端Remote/客户端)远距离去控制另一台电脑(被控端 Host/服务器端)的技术,主要通过远程控制软件实现。
远程控制软件工作原理:远程控制软件一般分客户端程序(Client)和服务器端程序(Server)两部分,通常将客户端程序安装到主控端的电脑上,将服务器端程序安装到被控端的电脑上。使用时客户端程序向被控端电脑中的服务器端程序发出信号,建立一个特殊的远程服务,然后通过这个远程服务,使用各种远程控制功能发送远程控制命令,控制被控端电脑中的各种应用程序运行。
一.Mongodb在rancher上面部署:
命令如图:mongod --keyFile /data/key/keyfile --replSet rs --bind_ip localhost,prod
二.Mongodb在服务器上的配置keyfile
这个keyfile怎么生成的我也没试过,官网有一些解释但是没说具体怎么生成如图:
我们需要把这个文件放在:
这些添加好就可以互相添加服务了如图:
其实就是各个容器是不互相影响的,如何让他们在互通就需要互相添加你要用的服务
这个名称如果不配置就用默认的,看你要不要配置
Prod:
Master:
Slave:
三.Mongodb集群测试是否成功:
参考文献: https://wwwyiibaicom/mongodb/mongodb_quick_guidehtml
四.Mongodb管理界面mongo-express搭建
成功日志:
五.Mongodb整合对外端口搭建haproxy
表标PHP已经自带了mongo功能,你就可以操作下面的代码(但是你必须有安装mongodb服务器)
一、连接数据库
使用下面的代码创建一个数据库链接
复制代码 代码如下:
<php
$connection = new Mongo(mongodb://19216815:27017); //链接到 19216815:27017//27017端口是默认的。
$connection = new Mongo( "examplecom" ); //链接到远程主机(默认端口)
$connection = new Mongo( "examplecom:65432" ); //链接到远程主机的自定义的端口
print_r($connection->listDBs());//能打印出数据库数组,看看有几个数据库。
>
如图:
上图说有一个数据库名字叫local,总大小1个字节,他是空的。看见ok表示运行成功。
现在你可以使用$connection链接来操作数据库了
选择数据库
使用下面的代码来选择一个数据库
复制代码 代码如下:
<php
$db = $connection->dbname;
>
这里的数据库并不一定是一个已经存在的数据库,如果所选择的数据库不存在,则会新建一个数据库,所以在选择数据库的时候,注意一定要填上正确的数据库名
如果拼写错误的话,很有可能会新建一个数据库
复制代码 代码如下:
<php
$db = $connection->mybiglongdbname;
//做一些事情
$db = $connection->mybiglongdbnme;
//现在会连上一个新的数据库
>
获取一个集合
获取一个集合跟选择数据库拥有相同的语法格式
复制代码 代码如下:
<php
$db = $connection->baz;//选择数据库
$collection = $db->foobar;//选择foobar集合
//或者使用更简洁的方式
$collection = $connection->baz->foobar;
>
插入一个文档
多维数组是可以被储存到数据库中的基本单元
一个随机的文档可能是这样
复制代码 代码如下:
<php
$doc = array(
”name” => “MongoDB”,
“type” => “database”,
“count” => 1,
“info” => (object)array( “x” => 203,
“y” => 102),
“versions” => array(“097″, “098″, “099″)
);
>
注意:你可以嵌套数组与对象,对象与文档在mongodb中几乎是一样的,你可以使用$doc调用一个文档或对象,但是info字段总是一个对象而不是一个文档,
本约束适用于所有文档
使用MongoCollection::insert()插入一个文档
复制代码 代码如下:
<php
$m = new Mongo();
$collection = $m->foo->bar;
$collection->insert($doc);
>
mongodb 的 insert()、save() ,区别主要是:若存在主键,insert() 不做操作,而save() 则更改原来的内容为新内容。
存在数据: { _id : 1, " name " : " n1 " }
insert({ _id : 1, " name " : " n2 " }) 会提示错误
save({ _id : 1, " name " : " n2 " }) 会把 n1 改为 n2 。
使用MongoCollection::findOne()查询文档
为了证明上面那段代码的数据已经插入到数据库里了,我们进行简单的 findOne()操作以得到集合中的第一个文档数据,这种方法只返回一个文档数据,
这种方法适用于在你的查询语句的时候只匹配一个文档或者你只关心第一条数据
复制代码 代码如下:
<php
$obj = $collection->findOne();
var_dump( $obj );
>
你会看到下列结果
复制代码 代码如下:
array(5) {
["_id"]=>
object(MongoId)#6 (0) {
}
["name"]
string(7) “MongoDB”
["type"]=>
string(8) “database”
["count"]=>
int(1)
["info"]=>
array (2) {
["x"]=>
int(203)
["y"]=>
int(102)
}
["versions"]
array(3) {
[0]=>
string(5) “097″
[1]=>
string(5) “098″
[2]=>
string(5) “099″
}
}
注意_id字段自动加载了文档上,MongoDB储存元素中以_以及$开头的都是供内部使用的
添加更多文档
为了做一些更有趣的事情,我们添加更多简单的文档到集合中,这些文档如下
复制代码 代码如下:
<php
array( “i” => value );
>
我们可以使用循环相当有效的插入数据
复制代码 代码如下:
<php
for($i=0; $i<100; $i++) {
$collection->insert( array( “i” => $i ) );
}
>
注意:我们可以插入不同的字段在同一字符集中,在这方面意味着MongoDB拥有非常自由的储存模式
在一个集合中计算文档的数量
现在我们插入了101个文档(我们用循环插入了100个,之前还插入了一个),我们可以使用count()来看看我们的数据是不是都被插入进去了
复制代码 代码如下:
<php
echo $collection->count();
>
这段代码将打印出101
MongoCollection::count() 也可以查询字段数据
使用游标得到集合中的所有文档
为了得到集合中的所有文档,我们可以使用 MongoCollection::find()方法,find()方法返回一个 MongoCursor对象,可以让我们重复得到查询所匹配的的文档
复制代码 代码如下:
<php
$cursor = $collection->find();
foreach ($cursor as $id => $value) {
echo “$id: “;
var_dump( $value );
}
>
这样我们会打印出集合中的这101个文档,$id就是文档中的_id字段,$value 就是文档本身
为查询规定一个标准
我们可以通过find()方法得到集合中的文档子集,例如,我们要查询出集合中i字段为71的文档,我们可以使用下列方法
复制代码 代码如下:
<php
$query = array( “i” => 71 );
$cursor = $collection->find( $query );
while( $cursor->hasNext() ) {
var_dump( $cursor->getNext() );
}
>
我们将打印如下数据
复制代码 代码如下:
array(2) {
["_id"]=>
object(MongoId)#6 (0) {
}
["i"]=>
int(71)
["_ns"]=>
“testCollection”
}
为查询设定一个范围
我们可以通过find()创建一个查询语句以得集合中的一个子集,例如如果我们得到所有”i”>50的文档,我们可以使用如下代码
复制代码 代码如下:
<php
$query = array( “i” => array(‘$gt' =>50)); //注意'$gt'两边的单引号
$cursor = $coll->find( $query );
while( $cursor->hasNext() ) {
var_dump( $cursor->getNext() );
}
>
我们同样可以得到20 < i <= 30之间的数据
复制代码 代码如下:
<php
$query = array( “i” => array( “\$gt” => 20, “\$lte” => 30 ) );
$cursor = $coll->find( $query );
while( $cursor->hasNext() ) {
var_dump( $cursor->getNext() );
}
>
我们非常容易漏掉$美元符号,你也可以选择你自定义的符号来代替美元符号,选择一个不会在你的建里面出现的符号例如”:”,在phpini中加上这么一句话
复制代码 代码如下:
mongocmd = “:”
那么上面的代码就可以替换成
复制代码 代码如下:
<php
$query = array( “i” => array( “:gt” => 20, “:lte” => 30 ) );
>
当然你也可以使用ini_set(“mongocmd”, “:”)的方法来改变
创建一个索引
MongoDB支持索引,并且可以很容易的加到一个集合中,你只要指定某个字段为索引就行了,并且还可以指定 正序索引(1)与 倒序索引(-1)
下面的代码为I创建了索引
复制代码 代码如下:
<php
$coll->ensureIndex( array( “i” => 1 ) ); //在”i”上创建了一个索引
$coll->ensureIndex( array( “i” => -1, “j” => 1 ) );//在”i”上创建了倒序索引 在”j”上创建了正序索引
>
一个完整的简单例子
这个例子展示了如何链接mongodb数据库,如何选择数据库,如何插入数据,如何查询数据,以及关闭数据库链接
复制代码 代码如下:
<php
//链接
$m = new Mongo();
// 选择一个数据库
$db = $m->comedy;
$collection = $db->cartoons;
//添加一个元素
$obj = array( "title" => "Calvin and Hobbes", "author" => "Bill Watterson" );
$collection->insert($obj);
//修改
$newdata = array('$set' => array("title" => "Calvin and Hobbes"));
$collection->update(array("author" => "caleng"), $newdata);
//删除
$collection->remove(array('author'=>'caleng'), array("justOne" => true));
//添加另一个元素,使用不同的格式
$obj = array( "title" => "XKCD", "online" => true );
$collection->insert($obj);
//查询所有的集合
$cursor = $collection->find();
//重复显示结果
foreach ($cursor as $obj) {
echo $obj["title"] "\n";
}
// 关闭链接
$m->close();
>
输出结果为
复制代码 代码如下:
Calvin and Hobbes
XKCD
0条评论