PHP操作Mongodb

小编复习MongoDB,基础请参考:MongoDB-CSDN博客(主要是linux操作)

PHP操作

<?php

/**

* 注意 本类仅适用于PHP7.0版本以上

* 请注意:mongoDB 支持版本 3.2+

* mongo具体参数参考: https://docs.mongodb.com/manual/reference/command/

*/

class MyMongodb {

private $manager;

private $dbname='yun';

/**

* 创建实例

* @param string $confkey

* @return object

*/

public function __construct($dns){

this-\>manager = new MongoDB\\Driver\\Manager(dns);

}

/**

* 插入

*/

public function insert(table,data){

$bulk = new MongoDB\Driver\BulkWrite;

bulk-\>insert(data);

$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);

res = this->manager->executeBulkWrite(this-\>dbname.'.'.table, bulk, writeConcern);

return $res?true:false;

}

public function insert_batch(table,data)

{

$bulk = new MongoDB\Driver\BulkWrite;

foreach (data as val){

bulk-\>insert(val);

}

$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);

res = this->manager->executeBulkWrite(this-\>dbname.'.'.table, bulk, writeConcern);

return $res?true:false;

}

/**

* 查询

* eg:'age' =\> 24]

* eg;$options = [

* 'projection' => '_id' =\> 0, //不输出_id字段

* 'sort' => 'leavetime'=\>-1 //根据user_id字段排序 1是升序,-1是降序

* ];

*/

public function select(table,filter,$options=array()){

!$filter && dieError('param of filter is error');

$options'projection'='_id' =\> 0;

query = new MongoDB\\Driver\\Query(filter, $options); //查询请求

cursor = this->manager->executeQuery(this-\>dbname.'.'.table, $query);

$result = \[\];

foreach(cursor as doc) {

result\[\] = (array)doc;

}

return $result;

}

/**

* 修改

* eg:$condition='name' =\> 'JetWu5'

* eg:set_array= \['set' => 'age' =\> 30, 'promise' =\> 'always smile!']

*/

public function update(table,condition=array(),$set_array=array()){

!$condition && dieError('param of condition is error');

!$set_array && dieError('param of set_array is error');

$bulk = new MongoDB\Driver\BulkWrite;

$bulk->update(

$condition,

$set_array

);

$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认

res = this->manager->executeBulkWrite(this-\>dbname.'.'.table, bulk, writeConcern);

return $res?true:false;

}

/**

* 删除

* eg:$condition='name' =\> 'JetWu5'

* if $condition==\[\] then delete all table documents!

*/

public function delete(table,condition=\[\]){

!is_array($condition) && dieError('param of condition is error');

$bulk = new MongoDB\Driver\BulkWrite;

bulk-\>delete(condition);

$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认

res = this->manager->executeBulkWrite(this-\>dbname.'.'.table, bulk, writeConcern);

return $res?true:false;

}

function exec($opts) {

cmd = new MongoDB\\Driver\\Command(opts);

cursor = this->manager->executeCommand(this-\>dbname, cmd);

$result = \[\];

foreach(cursor as doc) {

result\[\] = (array)doc;

}

return $result;

}

}

关键字

$eq:等于

$gt:大于

$gte:大于等于

$lt:小于

$lte:小于等于

$ne:不等于

$in:在指定数组中

$nin:不在指定数组中

$and:逻辑与

$or:逻辑或

$not:逻辑非

$exists:字段是否存在

//数据库链接

$mongodb = new MongoDB\Driver\Manager('mongodb://localhost:27017');

//数据写入

$bulk = new MongoDB\Driver\BulkWrite;

$bulk->insert('x' =\> 1, 'name'=\>'测试数据1', 'type' =\> 1,'desc'=\>'描述1');

$bulk->insert('x' =\> 2, 'name'=\>'测试数据2', 'type' =\> 2,'desc'=\>'描述2');

$bulk->insert('x' =\> 3, 'name'=\>'测试数据3', 'type' =\> 1,'desc'=\>'描述3');

$bulk->insert('x' =\> 4, 'name'=\>'测试数据4', 'type' =\> 2,'desc'=\>'描述4');

$bulk->insert('x' =\> 5, 'name'=\>'测试数据5', 'type' =\> 1,'desc'=\>'描述5');

$bulk->insert('x' =\> 6, 'name'=\>'测试数据6', 'type' =\> 2,'desc'=\>'描述6');

mongodb-\>executeBulkWrite('message.test', bulk);//数据写入(写入meaasge库的test表)

//数据查询

filter = \['x' =\> \['lte' => 3]];

$options = [

'projection' => '_id' =\> 0,

'sort' => 'x' =\> 1,

];

query = new MongoDB\\Driver\\Query(filter, $options); // 查询数据(预处理语句)

cursor = mongodb->executeQuery('message.test', $query);//执行查询

foreach (cursor as document) {//数据循环输出

print_r($document);

}

//数据修改

$bulk = new MongoDB\Driver\BulkWrite;

$bulk->update(

'x' =\> 2,

'$set' =\> \['name' =\> '测试数据22', 'desc' =\> '描述22'],

'multi' =\> false, 'upsert' =\> false

);

$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);

result = mongodb->executeBulkWrite('message.test', bulk, writeConcern);

var_dump($result);

//数据删除

$bulk = new MongoDB\Driver\BulkWrite;

$bulk->delete('x' =\> 1, 'limit' =\> 1); // limit 为 1 时,删除第一条匹配数据,limit 为 0 时,删除所有匹配数据

$writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);

result = mongodb->executeBulkWrite('message.test', bulk, writeConcern);

var_dump($result);

die;

相关推荐
溜达的大象8 小时前
服务器挂了等用户报障?我用Prometheus搭了一套监控告警,服务器出状况第一时间通知我
服务器·php·prometheus
代码中介商9 小时前
C++左值与右值:核心判断法则详解
开发语言·c++
JAVA9659 小时前
JAVA面试-并发篇 05-并发包AQS队列实现原理是什么
java·开发语言·面试
Halo_tjn10 小时前
反射与设计模式1
java·开发语言·算法
珊瑚里的鱼10 小时前
手撕单例模式中的饿汉模式和懒汉模式,懒汉模式还要再多加一个C++11版本的
开发语言·c++·单例模式
_不会dp不改名_11 小时前
python-opencv环境搭建
开发语言·python·opencv
HappyAcmen11 小时前
9.复盘API全套流程
开发语言·python
charlie11451419111 小时前
通用GUI编程技术——图形渲染实战(四十五)——D3D12资源与堆管理:从上传到驻留
开发语言·3d·图形渲染·win32
不会C语言的男孩11 小时前
C++ Primer 第12章:动态内存
开发语言·c++
踏着七彩祥云的小丑11 小时前
Go学习第1天:入门
开发语言·学习·golang·go