php操作mongodb封装类与用法实例


Posted in PHP onSeptember 01, 2018

本文实例讲述了php操作mongodb封装类与用法。分享给大家供大家参考,具体如下:

近来学习了mongodb,刚好是做php开发的,随便写了php操作mongodb的封装类.

<?php
/**
 * Created by PhpStorm.
 * User: lee
 * Date: 2016/10/24
 * Time: 13:49
 */
namespace App\Http\Controllers\Api;
use App\Http\Common\ReturnApi;
/*
 *
 *
 mongdb常规操作
 */
class MongdbCommonController
{
  private static $conn;
  private static $mon;
  private static $error;
  private function __construct(){
    //self::$conn = new \MongoClient("mongodb://".env('MONGDB_USER').":".env('MONGDB_PASS')."@".env('MONGDB_HOST').":".env('MONGDB_PORT')."/".env('MONGDB_DB'));
    self::$conn = new \MongoClient("mongodb://".env('MONGDB_USER').":".env('MONGDB_PASS')."@".env('MONGDB_HOST').":".env('MONGDB_PORT'));
    //self::$conn = new \MongoClient("mongodb://".env('MONGDB_HOST').":".env('MONGDB_PORT'));
    $db = env('MONGDB_DB');
    self::$mon = self::$conn->$db;
  }
  public static function getInstance(){
    if(!(self::$conn instanceof self)){
      self::$conn = new self();
    }
    //return self::$conn->mydb;
    return self::$conn;
  }
  private function __clone(){
    trigger_error('Clone is not allowed');
  }//禁止克隆
  //创建索引
  public function ensureIndex($table, $index, $index_param=array())
  {
    $index_param['safe'] = 1;
    try {
      self::$mon->$table->ensureIndex($index, $index_param);
      return true;
    }
    catch (MongoCursorException $e)
    {
      self::$error = $e->getMessage();
      return false;
    }
  }
  //添加
  public function insert($table,$arr){
    try {
      self::$mon->$table->insert($arr, array('w'=>true));
      return true;
    }
    catch (MongoCursorException $e)
    {
      self::$error = $e->getMessage();
      return false;
    }
  }
  //更新
  public function update($table, $condition, $new_arr, $options=array())
  {
    $options['w'] = 1;
    if (!isset($options['multiple']))
    {
      $options['multiple'] = 0;
    }
    try {
      self::$mon->$table->update($condition, $new_arr, $options);
      return true;
    }
    catch (MongoCursorException $e)
    {
      self::$error = $e->getMessage();
      return false;
    }
  }
  //删除
  public function remove($table, $condition, $options=array())
  {
    $options['w'] = 1;
    try {
      self::$mon->$table->remove($condition, $options);
      return true;
    }
    catch (MongoCursorException $e)
    {
      self::$error = $e->getMessage();
      return false;
    }
  }
  //查找
  public function find($table, $query_condition, $result_condition=array(), $fields=array())
  {
    $cursor = self::$mon->$table->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 (MongoCursorTimeoutException $e)
    {
      self::$error = $e->getMessage();
      return false;
    }
    return $result;
  }
  //查找一条记录
  public function findOne($table, $condition, $fields=array())
  {
    return self::$mon->$table->findOne($condition, $fields);
  }
  //返回表的记录数
  public function count($table)
  {
    return self::$mon->$table->count();
  }
  //返回错误信息
  public function getError()
  {
    return self::$error;
  }
}

操作实例:

use App\Http\Controllers\Api\MongdbCommonController;
$db = MongdbCommonController::getInstance();
$collection = 'tab';
$data = array('tt' =>'sdsd',
 'pp'  => 'ssdsdf');
//返回记录数
echo $db->count($collection);
//插入记录
$db->insert($collection, array("id"=>2, "title"=>"asdqw"));
//更新
$db->update($collection, array("id"=>2),array('tt'=>'dfdfd',"gg"=>"bbb",'hh'=>'dfsdsd'));
//查找记录
echo '<pre>';
print_r( $db->find($collection, array("tt"=>'dfdfd'), array("start"=>1,"limit"=>4)));
//删除
$db->remove($collection, array('tt' =>'sdsd'));

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
使用PHP获取网络文件的实现代码
Jan 01 PHP
PHP GD 图像处理组件的常用函数总结
Apr 28 PHP
javascript,php获取函数参数对象的代码
Feb 03 PHP
PHP中空字符串介绍0、null、empty和false之间的关系
Sep 25 PHP
PHP中mb_convert_encoding与iconv函数的深入解析
Jun 21 PHP
php析构函数的简单使用说明
Aug 24 PHP
使用Composer安装Yii框架的方法
Mar 15 PHP
PHP互换两个变量值的方法(不用第三变量)
Nov 14 PHP
浅谈Coreseek、Sphinx-for-chinaese、Sphinx+Scws的区别
Dec 15 PHP
php中html_entity_decode实现HTML实体转义
Jun 13 PHP
PHP lcfirst()函数定义与用法
Mar 08 PHP
Yii框架分页技术实例分析
Aug 30 PHP
thinkphp集成前端脚手架Vue-cli的教程图解
Aug 30 #PHP
Django中通过定时任务触发页面静态化的处理方式
Aug 29 #PHP
PHP使用SMTP邮件服务器发送邮件示例
Aug 28 #PHP
PHP实现websocket通信的方法示例
Aug 28 #PHP
Yii2压缩PHP中模板代码的输出问题
Aug 28 #PHP
PHP实现的XXTEA加密解密算法示例
Aug 28 #PHP
PHP两个n位的二进制整数相加问题的解决
Aug 26 #PHP
You might like
php获取汉字首字母的函数
2013/11/07 PHP
ThinkPHP3.1新特性之内容解析输出详解
2014/06/19 PHP
php中eval函数的危害与正确禁用方法
2014/06/30 PHP
php实现的Cookies操作类实例
2014/09/24 PHP
php中strlen和mb_strlen用法实例分析
2016/11/12 PHP
mouse_on_title.js
2006/08/25 Javascript
做网页的一些技巧
2007/02/01 Javascript
原生js实现给指定元素的后面追加内容
2013/04/10 Javascript
Jquery实现仿腾讯娱乐频道焦点图(幻灯片)特效
2015/03/06 Javascript
深入分析jQuery的ready函数是如何工作的(工作原理)
2015/12/17 Javascript
微信小程序 教程之wxapp 视图容器 view
2016/10/19 Javascript
BootStrap的select2既可以查询又可以输入的实现代码
2017/02/17 Javascript
在js代码拼接dom对象到页面上的模板总结
2018/10/21 Javascript
Nuxt项目支持eslint+pritter+typescript的实现
2019/05/20 Javascript
JavaScript迭代器的含义及用法
2019/06/21 Javascript
基于Ionic3实现选项卡切换并重新加载echarts
2020/09/24 Javascript
python中reload(module)的用法示例详解
2017/09/15 Python
python opencv检测目标颜色的实例讲解
2018/04/02 Python
Django项目开发中cookies和session的常用操作分析
2018/07/03 Python
Python中的CSV文件使用&quot;with&quot;语句的方式详解
2018/10/16 Python
python实现指定字符串补全空格、前面填充0的方法
2018/11/16 Python
Python 实现域名解析为ip的方法
2019/02/14 Python
python re模块常见用法例举
2021/03/01 Python
css3绘制天猫logo实现代码
2012/11/06 HTML / CSS
深入理解css中vertical-align属性
2017/04/18 HTML / CSS
圣彼得堡鲜花配送:Semicvetic
2020/09/15 全球购物
代码中finally中的代码会不会执行
2012/02/06 面试题
医院办公室主任职责
2013/12/29 职场文书
小学校园活动策划
2014/01/30 职场文书
渔夫的故事教学反思
2014/02/14 职场文书
《唯一的听众》教学反思
2014/02/20 职场文书
中秋晚会活动方案
2014/08/31 职场文书
个人遵守党的政治纪律情况对照检查材料思想汇报
2014/09/25 职场文书
关于感谢信的范文
2015/01/23 职场文书
5种 JavaScript 方式实现数组扁平化
2021/10/05 Javascript
面试被问select......for update会锁表还是锁行
2021/11/11 MySQL