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数组函数序列 之shuffle()和array_rand() 随机函数使用介绍
Oct 29 PHP
php生成EAN_13标准条形码实例
Nov 13 PHP
php对称加密算法示例
May 07 PHP
ThinkPHP页面跳转success与error方法概述
Jun 25 PHP
PHP+FastCGI+Nginx配置PHP运行环境
Aug 07 PHP
ThinkPHP中Session用法详解
Nov 29 PHP
php微信开发之带参数二维码的使用
Aug 03 PHP
PHP+JQuery+Ajax实现分页方法详解
Aug 06 PHP
PHP常用字符串函数小结(推荐)
Aug 05 PHP
PHP从零开始打造自己的MVC框架之类的自动加载实现方法详解
Jun 03 PHP
PHP-FPM 设置多pool及配置文件重写操作示例
Oct 02 PHP
php框架知识点的整理和补充
Mar 01 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/06/30 PHP
php数组函数array_walk用法示例
2016/05/26 PHP
Yii视图操作之自定义分页实现方法
2016/07/14 PHP
常用PHP封装分页工具类
2017/01/14 PHP
PHP代码覆盖率统计详解
2020/07/22 PHP
获取服务器传来的数据 用JS去空格的正则表达式
2012/03/26 Javascript
用jquery模仿的a的title属性(兼容ie6/7)
2013/01/21 Javascript
jQuery文本框(input textare)事件绑定方法教程
2013/04/24 Javascript
jquery实现公告翻滚效果
2015/02/27 Javascript
AngularJS实现给动态生成的元素绑定事件的方法
2016/12/14 Javascript
Bootstarp基本模版学习教程
2017/02/01 Javascript
Angularjs使用指令做表单校验的方法
2017/03/31 Javascript
vue.js实现数据动态响应 Vue.set的简单应用
2017/06/15 Javascript
详解AngularJS跨页面传值(ui-router)
2017/08/23 Javascript
vue 实现全选全不选的示例代码
2018/03/29 Javascript
详解Vue2.0组件的继承与扩展
2018/11/23 Javascript
js+canvas实现简单扫雷小游戏
2021/01/22 Javascript
vue-quill-editor的使用及个性化定制操作
2020/08/04 Javascript
[01:15:36]加油刀塔第二期网络版
2014/08/09 DOTA
Python实现打印螺旋矩阵功能的方法
2017/11/21 Python
numpy中loadtxt 的用法详解
2018/08/03 Python
使用Python向C语言的链接库传递数组、结构体、指针类型的数据
2019/01/29 Python
python给微信好友定时推送消息的示例
2019/02/20 Python
对Python函数设计规范详解
2019/07/19 Python
selenium+PhantomJS爬取豆瓣读书
2019/08/26 Python
python中enumerate() 与zip()函数的使用比较实例分析
2019/09/03 Python
python使用html2text库实现从HTML转markdown的方法详解
2020/02/21 Python
html2canvas截图空白问题的解决
2020/03/24 HTML / CSS
Skyscanner阿联酋:全球领先的旅游搜索平台
2017/11/25 全球购物
美国领先的在线邮轮旅游公司:CruiseDirect
2018/06/07 全球购物
伦敦高达60%折扣的钻石珠宝商:Purely Diamonds
2018/06/24 全球购物
英国办公家具网站:Furniture At Work
2019/10/07 全球购物
秦兵马俑教学反思
2014/02/07 职场文书
聚美优品广告词改编
2014/03/14 职场文书
2019终止劳动合同协议书最新范本!
2019/07/09 职场文书
pandas中关于apply+lambda的应用
2022/02/28 Python