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 缓存函数代码
Aug 27 PHP
PHP文件读写操作之文件读取方法详解
Jan 13 PHP
PHP中usort在值相同时改变原始位置问题的解决方法
Nov 27 PHP
使用php+Ajax实现唯一校验实现代码[简单应用]
Nov 29 PHP
PHP中把错误日志保存在系统日志中(Windows系统)
Jun 23 PHP
简单介绍win7下搭建apache+php+mysql开发环境
Aug 06 PHP
制作个性化的WordPress登陆界面的实例教程
May 21 PHP
简单解析PHP程序的运行流程
Jun 23 PHP
PHP面向对象程序设计之对象生成方法详解
Dec 02 PHP
PHP中使用OpenSSL生成证书及加密解密
Feb 05 PHP
Laravel使用swoole实现websocket主动消息推送的方法介绍
Oct 20 PHP
在laravel中实现ORM模型使用第二个数据库设置
Oct 24 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连mysql和oracle数据库性能比较
2006/10/09 PHP
php在数组中查找指定值的方法
2015/03/17 PHP
php过滤所有的空白字符(空格、全角空格、换行等)
2015/10/27 PHP
Windows2003下php5.4安装配置教程(Apache2.4)
2016/06/30 PHP
JQuery-tableDnD 拖拽的基本使用介绍
2013/07/04 Javascript
javascript实用小函数使用介绍
2013/11/11 Javascript
javascript新建标签,判断键盘输入,以及判断焦点(示例代码)
2013/11/25 Javascript
利用浏览器全屏api实现js全屏
2014/01/16 Javascript
js日期、星座的级联显示代码
2014/01/23 Javascript
JavaScript中使用Math.floor()方法对数字取整
2015/06/15 Javascript
Bootstrap每天必学之级联下拉菜单
2016/03/27 Javascript
jQuery实现带延时功能的水平多级菜单效果【附demo源码下载】
2016/09/21 Javascript
JavaScript计算值然后把值嵌入到html中的实现方法
2016/10/29 Javascript
Bootstrap导航条学习使用(二)
2017/02/08 Javascript
jQuery.ajax向后台传递数组问题的解决方法
2017/05/12 jQuery
Angular.JS中指令ng-if的注意事项小结
2017/06/21 Javascript
关于laydate.js加载laydate.css路径错误问题解决
2017/12/27 Javascript
vue中简单弹框dialog的实现方法
2018/02/26 Javascript
浅谈Webpack核心模块tapable解析
2018/09/11 Javascript
微信小程序版本自动更新的方法
2019/06/14 Javascript
JS代码简洁方式之函数方法详解
2020/07/28 Javascript
webpack4从0搭建组件库的实现
2020/11/29 Javascript
[02:28]DOTA2亚洲邀请赛附加赛 RECAP赛事回顾
2015/01/29 DOTA
Python检测字符串中是否包含某字符集合中的字符
2015/05/21 Python
Python yield 使用浅析
2015/05/28 Python
Python切片操作深入详解
2018/07/27 Python
python使用opencv对图像mask处理的方法
2019/07/05 Python
python tkinter GUI绘制,以及点击更新显示图片代码
2020/03/14 Python
世界领先的以旅馆为主的在线预订平台:Hostelworld
2016/10/09 全球购物
美国手机支架公司:PopSockets
2019/11/27 全球购物
应届中专生自荐书范文
2014/02/13 职场文书
桥梁工程专业求职信
2014/04/21 职场文书
2017年大学生寒假社会实践活动总结
2016/04/06 职场文书
jQuery ajax - getScript() 方法和getJSON方法
2021/05/14 jQuery
Python 实现Mac 屏幕截图详解
2021/10/05 Python
Java 实战项目之家居购物商城系统详解流程
2021/11/11 Java/Android