1 2 3 4 5 6 |
# https://github.com/mongodb/mongo-php-driver/archive/master.zip # unzip master.zip # /usr/local/php/bin/phpize # ./config --with-php-config=/usr/local/php/bin/php-config # make # make install |
将mongo.so添加到php.ini
1 2 |
# vim /usr/local/php/etc/php.ini extension = mongo |
重启php-fpm生效
1 |
# /usr/local/php/sbin/php-fpm -y /usr/local/php/etc/php-fpm.comf |
php的mongodb扩展,提供了4个核心类接口
1). 针对mongodb的连接操作类MongoClient
http://www.php.net/manual/zh/class.mongoclient.php
2). 针对mongodb的数据库操作类MongoDB
http://www.php.net/manual/zh/class.mongodb.php
3). 针对mongodb的集合操作类MongoCollection
http://www.php.net/manual/zh/class.mongocollection.php
4). 针对mongodb的查询结果集(游标)操作类MongoCursor
http://www.php.net/manual/zh/class.mongocursor.php
连接MongoDB
mongodb驱动连接格式为:mongodb://[username:[email protected]]host1[:port1][,host2[:port2],…[,hostN[:portN]]][/[database][?options]],如:
mongodb://localhost
mongodb://user:password@localhost
mongodb://user:[email protected]/database
mongodb://example1.com:27017,example2.com:27017
mongodb://localhost,localhost:27018,localhost:27019
mongodb://host1,host2,host3/?slaveOk=true
mongodb://localhost/?safe=true
mongodb://host1,host2,host3/?safe=true;w=2;wtimeoutMS=2000
mongodb://rs1.example.com:27017,rs2.example.com:27017/?replicaSet=myReplSetName
mongodb://localhost/?journal=true&w=majority&wTimeoutMS=20000
具体含义参见《ttlsa教程系列之mongodb—(一)mongodb介绍》 http://www.ttlsa.com/html/1594.html
PHP连接实例:
1 2 3 4 5 |
< $ = new MongoClient $ = new MongoClient $ = new MongoClient array = "myReplSetName" $ = new MongoClient array = "myReplSetName" |
在连接到复制集时,用它来判断哪台是primary。返回主机名称、端口号、健康程度、状态(1-primary,2-secondary,0-other)、ping耗时、前一次ping的时间戳。
1 |
$ |
列出所有数据库,返回数据库名称、大小、是否为空以及总大小、ok状态。
1 |
$ |
选择数据库,返回数据库对象
1 2 3 |
$ = $ 或 $ = $ |
选择表(集合),返回文档集合对象
1 2 3 4 5 |
$ = $ col_name 或 $ = $ 或 $ = $ |
列出所有集合,返回集合对象
1 |
$ = $ |
获取当前选择的数据库名,返回数据库名
1 |
$ = $ |
删除当前数据库
1 |
$ |
设置slaveok状态(可读状态设置)
1 |
$ |
获取slaveok当前状态
1 |
$ |
插入数据MongoCollection::insert(array $a,array $options)
array $a 要插入的数组
array $options 选项:safe 是否返回操作结果信息;fsync 是否直接插入到物理硬盘;w 写入份数;timeout 超时时间
1 2 3 4 5 |
< $ = $ $ = array $ = array $ = $ $ |
删除集合中的记录MongoCollection::remove(array $criteria,array $options)
array $criteria 条件
array $options 选项: safe 是否返回操作结果; fsync 是否是直接影响到物理硬盘; justOne 是否只影响一条记录
1 2 3 4 5 |
< $ = $ $ = array $ = array $ = $ $ |
更新集合中的记录MongoCollection::update(array $criceria,array $newobj,array $options)
array $criteria 条件
array $newobj 要更新的内容
array $options 选项: safe 是否返回操作结果; fsync 是否是直接影响到物理硬盘; upsert 是否没有匹配数据就添加一条新的; multiple 是否影响所有符合条件的记录,默认只影响一条
1 2 3 4 5 6 |
< $ = $ $ = array $newobj = array(’vip‘ $ = array $ = $ $ |
查询集合获取单条记录MongoCollection::findOne(array $query,array $fields)
array $query 条件
array $fields 要获得的字段
1 2 3 4 5 |
< $ = $ $ = array $ = array $ = $ |
获取多条记录MongoCollection::find(array $query,array $fields)
array $query 条件
array $fields 要获得的字段
1 2 3 4 5 6 |
< $ = $ $ = array $ = array $ = array $ = $ |
获取查询结果数量
1 2 |
$ = $ $ = $ |
选定列MongoCursor::fields
1 2 3 |
$ = true column_name2 = false 或 $ = $ = true column_name2 = false |
分页
1 |
$ = $ |
排序MongoCursor::sort
1 |
$ = $ = - column_name2 = 1 |
取查询结果
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
$ = $ while $ = $ var_dump } 或者 $ = $ $ = array foreache $ var_dump $ = $ } 或者 $ = $ $ iterator_to_array |
快照MongoCursor::snapshot
保证一致性。在做find()操作时,获得$cursor之后,这个游标是动态的,在循环取结果过程中,如果有其他连接来更改符合条件的记录时,这个$cursor也会跟着变化的。$cursor->snapshot();之后,再插入或删除符合条件的记录时,获取的结果集将不再变化。如果是小于1M的结果集会自动被当作snapshot来处理。
如果要获取$cursor之后不变的结果需要这么做:
1 2 |
$ = $ $ |
snapshot对findOne无效。