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面向对象编程快速入门
Dec 14 PHP
PHP的单引号和双引号 字符串效率
May 27 PHP
PHP系统命令函数使用分析
Jul 05 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(十三)
Jun 26 PHP
php可生成缩略图的文件上传类实例
Dec 17 PHP
win7系统配置php+Apache+mysql环境的方法
Aug 21 PHP
php自动提交表单的方法(基于fsockopen与curl)
May 09 PHP
PHP中类的继承和用法实例分析
May 24 PHP
php实现的二分查找算法示例
Jun 20 PHP
PHP设计模式之注册树模式分析
Jan 26 PHP
PHP删除数组中特定元素的两种方法
Feb 28 PHP
laravel框架如何设置公共头和公共尾
Oct 22 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
收集的DedeCMS一些使用经验
2007/03/17 PHP
php判断ip黑名单程序代码实例
2014/02/24 PHP
PHPExcel 修改已存在Excel的方法
2018/05/03 PHP
JSON 学习之JSON in JavaScript详细使用说明
2010/02/23 Javascript
jQuery EasyUI API 中文文档 可调整尺寸
2011/09/29 Javascript
JQuery实现简单验证码提示解决方案
2012/12/20 Javascript
简单的js表单验证函数
2013/10/28 Javascript
input标签内容改变的触发事件介绍
2014/06/18 Javascript
JS在可编辑的div中的光标位置插入内容的方法
2014/11/20 Javascript
ECMAScript 5严格模式(Strict Mode)介绍
2015/03/02 Javascript
如何利用Promises编写更优雅的JavaScript代码
2016/05/17 Javascript
jQuery中table数据的值拷贝和拆分
2017/03/19 Javascript
js简易版购物车功能
2017/06/17 Javascript
使用MUI框架模拟手机端的下拉刷新和上拉加载功能
2017/09/04 Javascript
Angular CLI 安装和使用教程
2017/09/13 Javascript
JavaScript中错误正确处理方式小结你用对了吗
2017/10/10 Javascript
五步轻松实现zTree的使用
2017/11/01 Javascript
JsChart组件使用详解
2018/03/04 Javascript
Auto.js自动收取自己和好友蚂蚁森林能量脚本
2018/06/28 Javascript
Node.js操作MongoDB数据库实例分析
2020/01/19 Javascript
[01:24:34]2014 DOTA2华西杯精英邀请赛5 24 DK VS LGD
2014/05/25 DOTA
Python闭包实现计数器的方法
2015/05/05 Python
python爬虫之urllib库常用方法用法总结大全
2018/11/14 Python
Python实现钉钉发送报警消息的方法
2019/02/20 Python
python使用turtle绘制国际象棋棋盘
2019/05/23 Python
python实现集中式的病毒扫描功能详解
2019/07/09 Python
详解Anconda环境下载python包的教程(图形界面+命令行+pycharm安装)
2019/11/11 Python
解决pycharm安装第三方库失败的问题
2020/05/09 Python
如何从csv文件构建Tensorflow的数据集
2020/09/21 Python
使用CSS3实现圆角,阴影,透明
2014/12/23 HTML / CSS
HTML5 canvas基本绘图之图形组合
2016/06/27 HTML / CSS
英国潮流网站:END.(全球免邮)
2017/01/16 全球购物
尊老爱幼演讲稿
2014/09/04 职场文书
六查六看自查报告
2014/10/14 职场文书
先进典型发言材料
2014/12/30 职场文书
2015年保洁员工作总结
2015/05/04 职场文书