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使用CURL_MULTI实现多线程采集的例子
Jul 29 PHP
PHP下的Oracle客户端扩展(OCI8)安装教程
Sep 10 PHP
php简单实现无限分类树形列表的方法
Mar 27 PHP
PHP的运行机制与原理(底层)
Nov 16 PHP
thinkPHP中分页用法实例分析
Dec 26 PHP
浅谈mysql_query()函数的返回值问题
Sep 05 PHP
thinkphp实现把数据库中的列的值存到下拉框中的方法
Jan 20 PHP
php基于dom实现的图书xml格式数据示例
Feb 03 PHP
PHP查询分页的实现代码
Jun 09 PHP
PHP判断json格式是否正确的实现代码
Sep 20 PHP
解决在laravel中leftjoin带条件查询没有返回右表为NULL的问题
Oct 15 PHP
PHP单元测试配置与使用方法详解
Dec 27 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
不用数据库的多用户文件自由上传投票系统(1)
2006/10/09 PHP
数据库查询记录php 多行多列显示
2009/08/15 PHP
关于Sphinx创建全文检索的索引介绍
2013/06/25 PHP
PHP实现的DES加密解密封装类完整实例
2017/04/29 PHP
PHP聊天室简单实现方法详解
2018/12/08 PHP
laravel框架上传图片实现实时预览功能
2019/10/14 PHP
div移动 输入框不能输入的问题
2009/11/19 Javascript
jQuery动画效果-slideUp slideDown上下滑动示例代码
2013/08/28 Javascript
jquery 删除字符串最后一个字符的方法解析
2014/02/11 Javascript
jQuery之ajax删除详解
2014/02/27 Javascript
jQuery 仿百度输入标签插件附效果图
2014/07/04 Javascript
JavaScript设计模式之单例模式实例
2014/09/24 Javascript
JavaScript的Polymer框架中dom-repeat与VM的相关操作
2015/07/29 Javascript
深入理解javascript的getTime()方法
2017/02/16 Javascript
React Native 搭建开发环境的方法步骤
2017/10/30 Javascript
AjaxUpLoad.js实现文件上传
2018/03/05 Javascript
浅谈React的最大亮点之虚拟DOM
2018/05/29 Javascript
JS中call和apply函数用法实例分析
2018/06/20 Javascript
原生JS实现的轮播图功能详解
2018/08/06 Javascript
详解vue-cli+element-ui树形表格(多级表格折腾小计)
2019/04/17 Javascript
Echarts动态加载多条折线图的实现代码
2019/05/24 Javascript
Vue 中使用富文本编译器wangEditor3的方法
2019/09/26 Javascript
vue在线动态切换主题色方案
2020/03/26 Javascript
NodeJS配置CORS实现过程详解
2020/12/02 NodeJs
python设置windows桌面壁纸的实现代码
2013/01/28 Python
python实现自动登录人人网并采集信息的方法
2015/06/28 Python
Python中的上下文管理器和with语句的使用
2018/04/17 Python
Python基础之高级变量类型实例详解
2020/01/03 Python
python不使用for计算两组、多个矩形两两间的iou方式
2020/01/18 Python
pytorch 限制GPU使用效率详解(计算效率)
2020/06/27 Python
让IE6、IE7、IE8支持CSS3的脚本
2010/07/20 HTML / CSS
贝嫂喜欢的婴儿品牌,个性化的婴儿礼物:My 1st Years
2017/11/19 全球购物
BudgetAir印度:预订航班、酒店和汽车租赁
2019/07/07 全球购物
垂直极限观后感
2015/06/08 职场文书
实验心得体会范文
2016/01/25 职场文书
市语委办2016年第十九届“推普周”活动总结
2016/04/05 职场文书