php mongodb操作类 带几个简单的例子


Posted in PHP onAugust 25, 2016

之前三水点靠木已经发过几篇类似的文章,大家可以参考一下。

核心代码:

class NewMongodb {  
  private $mongo;  //NewMongodb连接
  private $curr_db_name;
  private $curr_table_name;
  private $error;
  public $config;
  public function getInstance($mongo_server, $flag=array())
  {
    static $NewMongodb_arr;
    if (empty($flag['tag']))
    {
      $flag['tag'] = 'default';     }
    if (isset($flag['force']) && $flag['force'] == true)
    {
      $mongo = new NewMongodb($mongo_server);
      if (empty($NewMongodb_arr[$flag['tag']]))
      {
        $NewMongodb_arr[$flag['tag']] = $mongo;
      }
      return $mongo;
    }
    else if (isset($NewMongodb_arr[$flag['tag']]) && is_resource($NewMongodb_arr[$flag['tag']]))
    {
      return $NewMongodb_arr[$flag['tag']];
    }
    else
    {
      $mongo = new NewMongodb($mongo_server);
      $NewMongodb_arr[$flag['tag']] = $mongo;
      return $mongo;
    }
  }
  /**
   * 构造函数
   * 支持传入多个mongo_server(1.一个出问题时连接其它的server 2.自动将查询均匀分发到不同server)
   *
   * 参数:
   * $mongo_server:数组或字符串-array("127.0.0.1:1111", "127.0.0.1:2222")-"127.0.0.1:1111"
   * $connect:初始化mongo对象时是否连接,默认连接
   * $auto_balance:是否自动做负载均衡,默认是
   *
   * 返回值:
   * 成功:mongo object
   * 失败:false
   */
  public function __construct($mongo_server, $connect=true, $auto_balance=true)
  {
   if (is_array($mongo_server))
   {
   $mongo_server_num = count($mongo_server);
   if ($mongo_server_num > 1 && $auto_balance)
   {
    $prior_server_num = rand(1, $mongo_server_num);
    $rand_keys = array_rand($mongo_server,$mongo_server_num);
    $mongo_server_str = $mongo_server[$prior_server_num-1];
    foreach ($rand_keys as $key)
    {
    if ($key != $prior_server_num - 1)
    {
     $mongo_server_str .= ',' . $mongo_server[$key];
    }
    }
   }
   else
   {
    $mongo_server_str = implode(',', $mongo_server);
   }         }
   else
   {
    $mongo_server_str = $mongo_server;
   }
   try {
    $this->mongo = new MongoClient($mongo_server, array('connect'=>$connect));
   }
   catch (MongoConnectionException $e)
   {
    $this->error = $e->getMessage();
    return false;
   }
  }
  
  /**
  * 连接NewMongodb server
  *
  * 参数:无
  *
  * 返回值:
  * 成功:true
  * 失败:false
  */
  public function connect()
  {
    try {
      $this->mongo->connect();
      return true;
    }
    catch (MongoConnectionException $e)
    {
      $this->error = $e->getMessage();
      return false;
    }
  }  
  /**
  * select db
  *
  * 参数:$dbname
  *
  * 返回值:无
  */
  public function selectDb($dbname)
  {
    $this->curr_db_name = $dbname;
  }  
  /**
  * 创建索引:如索引已存在,则返回。
  *
  * 参数:
  * $table_name:表名
  * $index:索引-array("id"=>1)-在id字段建立升序索引
  * $index_param:其它条件-是否唯一索引等
  *
  * 返回值:
  * 成功:true
  * 失败:false
  */
  public function ensureIndex($table_name, $index, $index_param=array())
  {
    $dbname = $this->curr_db_name;
    $index_param['safe'] = 1;
    try {
      $this->mongo->$dbname->$table_name->ensureIndex($index, $index_param);
      return true;
    }
    catch (MongoCursorException $e)
    {
      $this->error = $e->getMessage();
      return false;
    }
  }
  /**
  * 插入记录
  *
  * 参数:
  * $table_name:表名
  * $record:记录
  *
  * 返回值:
  * 成功:true
  * 失败:false
  */
  public function insert($table_name, $record)
  {
    $dbname = $this->curr_db_name;
    try {
      $this->mongo->$dbname->$table_name->insert($record, array('safe'=>true));
      return true;
    }
    catch (MongoCursorException $e)
    {
      $this->error = $e->getMessage();
      return false;
    }
  }  
  /**
  * 查询表的记录数
  *
  * 参数:
  * $table_name:表名
  *
  * 返回值:表的记录数
  */
  public function count($table_name)
  {
    $dbname = $this->curr_db_name;
    return $this->mongo->$dbname->$table_name->count();
  }  
  /**
  * 更新记录
  *
  * 参数:
  * $table_name:表名
  * $condition:更新条件
  * $newdata:新的数据记录
  * $options:更新选择-upsert/multiple
  *
  * 返回值:
  * 成功:true
  * 失败:false
  */
  public function update($table_name, $condition, $newdata, $options=array())
  {
    $dbname = $this->curr_db_name;
    $options['safe'] = 1;
    if (!isset($options['multiple']))
    {
      $options['multiple'] = 0;     }
    try {
      $this->mongo->$dbname->$table_name->update($condition, $newdata, $options);
      return true;
    }
    catch (MongoCursorException $e)
    {
      $this->error = $e->getMessage();
      return false;
    }
  }  
  /**
  * 删除记录
  *
  * 参数:
  * $table_name:表名
  * $condition:删除条件
  * $options:删除选择-justOne
  *
  * 返回值:
  * 成功:true
  * 失败:false
  */
  public function remove($table_name, $condition, $options=array())
  {
    $dbname = $this->curr_db_name;
    $options['safe'] = 1;
    try {
      $this->mongo->$dbname->$table_name->remove($condition, $options);
      return true;
    }
    catch (MongoCursorException $e)
    {
      $this->error = $e->getMessage();
      return false;
  }  }  
  /**
  * 查找记录
  *
  * 参数:
  * $table_name:表名
  * $query_condition:字段查找条件
  * $result_condition:查询结果限制条件-limit/sort等
  * $fields:获取字段
  *
  * 返回值:
  * 成功:记录集
  * 失败:false
  */
  public function find($table_name, $query_condition, $result_condition=array(), $fields=array())
  {
    $dbname = $this->curr_db_name;
    $cursor = $this->mongo->$dbname->$table_name->find($query_condition, $fields);
    if (!empty($result_condition['start']))
    {
      $cursor->skip($result_condition['start']);
    }
    if (!empty($result_condition['limit']))
    {
      $cursor->limit($result_condition['limit']);
    }
    if (!empty($result_condition['sort']))
    {
      $cursor->sort($result_condition['sort']);
    }
    $result = array();
    try {
      while ($cursor->hasNext())
      {
        $result[] = $cursor->getNext();
      }
    }
    catch (MongoConnectionException $e)
    {
      $this->error = $e->getMessage();
      return false;
    }
    catch (MongoCursorTimeoutException $e)
    {
      $this->error = $e->getMessage();
      return false;
    }
    return $result;
  }  
  /**
  * 查找一条记录
  *
  * 参数:
  * $table_name:表名
  * $condition:查找条件
  * $fields:获取字段
  *
  * 返回值:
  * 成功:一条记录
  * 失败:false
  */
  public function findOne($table_name, $condition, $fields=array())
  {
    $dbname = $this->curr_db_name;
    return $this->mongo->$dbname->$table_name->findOne($condition, $fields);
  }  
  /**
  * 获取当前错误信息
  *
  * 参数:无
  *
  * 返回值:当前错误信息
  */
  public function getError()
  {
    return $this->error;
  }
  /*** NewMongodb类** examples:
   * $mongo = new NewMongodb("127.0.0.1:11223");
  * $mongo->selectDb("test_db");
  * 创建索引
  * $mongo->ensureIndex("test_table", array("id"=>1), array('unique'=>true));
  * 获取表的记录
  * $mongo->count("test_table");
  * 插入记录
  * $mongo->insert("test_table", array("id"=>2, "title"=>"asdqw"));
  * 更新记录
  * $mongo->update("test_table", array("id"=>1),array("id"=>1,"title"=>"bbb"));
  * 更新记录-存在时更新,不存在时添加-相当于set
  * $mongo->update("test_table", array("id"=>1),array("id"=>1,"title"=>"bbb"),array("upsert"=>1));
  * 查找记录
  * $mongo->find("c", array("title"=>"asdqw"), array("start"=>2,"limit"=>2,"sort"=>array("id"=>1)))
  * 查找一条记录
  * $mongo->findOne("$mongo->findOne("ttt", array("id"=>1))", array("id"=>1));
  * 删除记录
  * $mongo->remove("ttt", array("title"=>"bbb"));
  * 仅删除一条记录
  * $mongo->remove("ttt", array("title"=>"bbb"), array("justOne"=>1));
  * 获取Mongo操作的错误信息
  * $mongo->getError();
  */
}
PHP 相关文章推荐
计数器详细设计
Oct 09 PHP
php xml 入门学习资料
Jan 01 PHP
理解和运用PHP中的多态性[译]
Aug 02 PHP
关于js和php对url编码的处理方法
Mar 04 PHP
php 判断网页是否是utf8编码的方法
Jun 06 PHP
php在linux下检测mysql同步状态的方法
Jan 15 PHP
PHP下载生成的csv文件及问题总结
Aug 06 PHP
基于OpenCart 开发支付宝,财付通,微信支付参数错误问题
Oct 01 PHP
详解WordPress中用于更新和获取用户选项数据的PHP函数
Mar 08 PHP
CodeIgniter 完美解决URL含有中文字符串
May 13 PHP
利用php-cli和任务计划实现刷新token功能的方法
May 03 PHP
PHP开发实现快递查询功能详解
Apr 08 PHP
php flush无效,IIS7下php实时输出的方法
Aug 25 #PHP
php 的反射详解及示例代码
Aug 25 #PHP
php 输入输出流详解及示例代码
Aug 25 #PHP
PHP 输出缓冲控制(Output Control)详解
Aug 25 #PHP
PHP中利用sleep函数实现定时执行功能实现代码
Aug 25 #PHP
PHP sleep()函数, usleep()函数
Aug 25 #PHP
PHP页面间传递值和保持值的方法
Aug 24 #PHP
You might like
php mssql 分页SQL语句优化 持续影响
2009/04/26 PHP
phpmyadmin 常用选项设置详解版
2010/03/07 PHP
php检测用户是否用手机(Mobile)访问网站的类
2014/01/09 PHP
php实现把url转换迅雷thunder资源下载地址的方法
2014/11/07 PHP
document.documentElement && document.documentElement.scrollTop
2007/12/01 Javascript
点图片上一页下一页翻页效果
2008/07/09 Javascript
一个简单的jQuery插件制作 学习过程及实例
2010/04/25 Javascript
JavaScript prototype属性深入介绍
2012/11/27 Javascript
jQuery中DOM树操作之使用反向插入方法实例分析
2015/01/23 Javascript
js判断子窗体是否关闭的方法
2015/08/11 Javascript
关于获取DIV内部内容报错的原因分析及解决办法
2016/01/29 Javascript
Ionic如何创建APP项目
2016/06/03 Javascript
Three.js学习之Lamber材质和Phong材质
2016/08/04 Javascript
自己封装的一个简单的倒计时功能实例
2016/11/23 Javascript
如何用js判断dom是否有存在某class的值
2017/02/13 Javascript
使用jquery datatable和bootsrap创建表格实例代码
2017/03/17 Javascript
js编写选项卡效果
2017/05/23 Javascript
js 获取html5的data属性实现方法
2017/07/28 Javascript
jQuery中内容过滤器简单用法示例
2018/03/31 jQuery
基于vue的验证码组件的示例代码
2019/01/22 Javascript
vscode配置vue下的es6规范自动格式化详解
2019/03/20 Javascript
Python使用asyncio包处理并发详解
2017/09/09 Python
python添加模块搜索路径方法
2017/09/11 Python
django迁移数据库错误问题解决
2019/07/29 Python
Pytorch 之修改Tensor部分值方式
2019/12/27 Python
django项目中新增app的2种实现方法
2020/04/01 Python
Keras设置以及获取权重的实现
2020/06/19 Python
HTML5 WebGL 实现民航客机飞行监控系统
2019/07/25 HTML / CSS
Public Desire美国/加拿大:全球性的在线鞋类品牌
2018/12/17 全球购物
简述DNS进行域名解析的过程
2013/12/02 面试题
应届毕业生的个人自我鉴定
2013/10/24 职场文书
群教个人对照检查材料
2014/08/20 职场文书
社区六一儿童节活动总结
2015/02/11 职场文书
孔繁森观后感
2015/06/10 职场文书
导游词之扬州大明寺
2019/10/09 职场文书
java实现web实时消息推送的七种方案
2022/07/23 Java/Android