php实现的mongodb操作类实例


Posted in PHP onApril 03, 2015

本文实例讲述了php实现的mongodb操作类。分享给大家供大家参考。具体如下:

<?php 
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */ 
class mongo_db { 
  private $config; 
  private $connection; 
  private $db; 
  private $connection_string; 
  private $host; 
  private $port; 
  private $user; 
  private $pass; 
  private $dbname; 
  private $persist; 
  private $persist_key; 
  private $selects = array(); 
  private $wheres = array(); 
  private $sorts = array(); 
  private $limit = 999999; 
  private $offset = 0; 
  private $timeout = 200; 
  private $key = 0; 
  /**
  *
  * CONSTRUCTOR *
  *
  * Automatically check if the Mongo PECL extension has been
  installed/enabled.
  * Generate the connection string and establish a connection
  to the MongoDB.
  */ 
  public function __construct() { 
    if((IS_NOSQL != 1)){ 
      return; 
    } 
    if (!class_exists('Mongo')) { 
      //$this->error("The MongoDB PECL extension has not been installed or enabled", 500); 
    } 
    $configs =wxcity_base::load_config("cache","mongo_db"); 
    $num = count($configs['connect']); 
    $this->timeout = trim($configs['timeout']); 
    $keys = wxcity_base::load_config('double'); 
    $this->key = $keys['mongo_db']; 
    $this->config = $configs['connect'][$this->key]; 
    $status = $this->connect(); 
    if($status == false) 
    { 
      for($i = 1; $i < $num; $i++) 
      { 
        $n = $this->key + $i; 
        $key = $n >= $num ? $n - $num : $n; 
        $this->config = $configs['connect'][$key]; 
        $status = $this->connect(); 
        if($status!=false) 
        { 
          $keys['mongo_db'] = $key ; 
          $this->key = $key; 
          $data = "<?php\nreturn ".var_export($keys, true).";\n?>"; 
          file_put_contents(WHTY_PATH.'configs/double.php', $data, LOCK_EX); 
          break; 
        } 
      } 
    } 
    if($status==false) 
    { 
      die('mongoDB not connect'); 
    } 
  } 
  function __destruct() { 
    if((IS_NOSQL != 1)){ 
      return; 
    } 
    if($this->connection) 
    { 
      $this->connection->close(); 
    } 
  } 
    /**
 *
 * CONNECT TO MONGODB  *
 *
 * Establish a connection to MongoDB using
 the connection string generated in
 * the connection_string() method.
 If 'mongo_persist_key' was set to true in the  
 * config file, establish a persistent connection.
 We allow for only the 'persist'
 * option to be set because we want to 
 establish a connection immediately.
 */ 
  private function connect() { 
    $this->connection_string(); 
    $options = array('connect'=>true,'timeout'=>$this->timeout); 
    try { 
      $this->connection = new Mongo($this->connection_string, $options); 
      $this->db = $this->connection->{$this->dbname}; 
      return($this); 
    } catch (MongoConnectionException $e) { 
      return false; 
    } 
  } 
  /**
  *
  * BUILD CONNECTION STRING *
  *
  * Build the connection string from the config file.
  */ 
  private function connection_string() { 
    $this->host = trim($this->config['hostname']); 
    $this->port = trim($this->config['port']); 
    $this->user = trim($this->config['username']); 
    $this->pass = trim($this->config['password']); 
    $this->dbname = trim($this->config['database']); 
    $this->persist = trim($this->config['autoconnect']); 
    $this->persist_key = trim($this->config['mongo_persist_key']); 
    $connection_string = "mongodb://"; 
    if (emptyempty($this->host)) { 
      $this->error("The Host must be set to connect to MongoDB", 500); 
    } if (emptyempty($this->dbname)) { 
      $this->error("The Database must be set to connect to MongoDB", 500); 
    } if (!emptyempty($this->user) && !emptyempty($this->pass)) { 
      $connection_string .= "{$this->user}:{$this->pass}@"; 
    } if (isset($this->port) && !emptyempty($this->port)) { 
      $connection_string .= "{$this->host}:{$this->port}"; 
    } else { 
      $connection_string .= "{$this->host}"; 
    } $this->connection_string = trim($connection_string); 
  } 
  /**
  *
  * Switch_db  *
  *
  * Switch from default database to a different db
  */ 
  public function switch_db($database = '') { 
    if (emptyempty($database)) { 
      $this->error("To switch MongoDB databases, a new database name must be specified", 500); 
    } $this->dbname = $database; 
    try { 
      $this->db = $this->connection->{$this->dbname}; 
      return(TRUE); 
    } catch (Exception $e) { 
      $this->error("Unable to switch Mongo Databases: {$e->getMessage()}", 500); 
    } 
  } 
  /**
  *
  * SELECT FIELDS  *
  *
  * Determine which fields to include OR which to
  exclude during the query process.
  * Currently, including and excluding at 
  the same time is not available, so the
  * $includes array will take precedence over
  the $excludes array.
  If you want to
  * only choose fields to exclude,
  leave $includes an empty array().
  *
  * @usage: $this->mongo_db->select(array('foo', 'bar'))->get('foobar');
  */ 
  public function select($includes = array(), $excludes = array()) { 
    if (!is_array($includes)) { 
      $includes = array(); 
    } 
    if (!is_array($excludes)) { 
      $excludes = array(); 
    } 
    if (!emptyempty($includes)) { 
      foreach ($includes as $col) { 
        $this->selects[$col] = 1; 
      } 
    } else { 
      foreach ($excludes as $col) { 
        $this->selects[$col] = 0; 
      } 
    } return($this); 
  } 
  /**
  *
  * WHERE PARAMETERS   *
  *
  * Get the documents based on these
  search parameters. The $wheres array should
  * be an associative array with the field 
  as the key and the value as the search
  * criteria.  *
  * @usage = $this->mongo_db->where(array('foo' => 'bar'))->get('foobar');
  */ 
  public function where($wheres = array()) { 
    foreach ((array)$wheres as $wh => $val) { 
      $this->wheres[$wh] = $val; 
    } return($this); 
  } 
  /**
  *
  * WHERE_IN PARAMETERS *
  *
  * Get the documents where the value 
  of a $field is in a given $in array().
  *
  * @usage = $this->mongo_db->where_in('foo', array('bar', 'zoo', 'blah'))->get('foobar');
  */ 
  public function where_in($field = "", $in = array()) { 
    $this->where_init($field); 
    $this->wheres[$field]['$in'] = $in; 
    return($this); 
  } 
  /**
  *
  * WHERE_NOT_IN PARAMETERS *
  *
  * Get the documents where the value of 
  a $field is not in a given $in array().
  *
  * @usage = $this->mongo_db->where_not_in('foo', array('bar', 'zoo', 'blah'))->get('foobar');
  */ 
  public function where_not_in($field = "", $in = array()) { 
    $this->where_init($field); 
    $this->wheres[$field]['$nin'] = $in; 
    return($this); 
  } 
  /**
  *
  * WHERE GREATER THAN PARAMETERS  *
  *
  * Get the documents where the value of 
  a $field is greater than $x
  * 
  * @usage = $this->mongo_db->where_gt('foo', 20);
  */ 
  public function where_gt($field = "", $x) { 
    $this->where_init($field); 
    $this->wheres[$field]['$gt'] = $x; 
    return($this); 
  } 
  /**
  *
  * WHERE GREATER THAN OR EQUAL TO PARAMETERS  *
  *
  * Get the documents where the value of a $field is greater than or equal to $x
  *
  * @usage = $this->mongo_db->where_gte('foo', 20);
  */ 
  public function where_gte($field = "", $x) { 
    $this->where_init($field); 
    $this->wheres[$field]['$gte'] = $x; 
    return($this); 
  } 
  /**
  *
  * WHERE LESS THAN PARAMETERS  *
  *
  * Get the documents where the value of
  a $field is less than $x
  *
  * @usage = $this->mongo_db->where_lt('foo', 20);
  */ 
  public function where_lt($field = "", $x) { 
    $this->where_init($field); 
    $this->wheres[$field]['$lt'] = $x; 
    return($this); 
  } 
  /**
  *
  * WHERE LESS THAN OR EQUAL TO PARAMETERS  *
  *
  * Get the documents where the value of 
  a $field is less than or equal to $x
  *
  * @usage = $this->mongo_db->where_lte('foo', 20);
  */ 
  public function where_lte($field = "", $x) { 
    $this->where_init($field); 
    $this->wheres[$field]['$lte'] = $x; 
    return($this); 
  } 
  /**
  *
  * WHERE BETWEEN PARAMETERS   *
  *
  * Get the documents where the value of
  a $field is between $x and $y
  *
  * @usage = $this->mongo_db->where_between('foo', 20, 30);
  */ 
  public function where_between($field = "", $x, $y) { 
    $this->where_init($field); 
    $this->wheres[$field]['$gte'] = $x; 
    $this->wheres[$field]['$lte'] = $y; 
    return($this); 
  } 
  /**
  *
  * WHERE BETWEEN AND NOT EQUAL TO PARAMETERS  *
  *
  * Get the documents where the value of 
  a $field is between but not equal to $x and $y
  *
  * @usage = $this->mongo_db->where_between_ne('foo', 20, 30);
  */ 
  public function where_between_ne($field = "", $x, $y) { 
    $this->where_init($field); 
    $this->wheres[$field]['$gt'] = $x; 
    $this->wheres[$field]['$lt'] = $y; 
    return($this); 
  } 
  /**
  *
  * WHERE NOT EQUAL TO PARAMETERS  *
  *
  * Get the documents where the value of 
  a $field is not equal to $x
  *
  * @usage = $this->mongo_db->where_between('foo', 20, 30);
  */ 
  public function where_ne($field = "", $x) { 
    $this->where_init($field); 
    $this->wheres[$field]['$ne'] = $x; 
    return($this); 
  } 
  /**
  *
  * WHERE OR   *
  *
  * Get the documents where the value of 
  a $field is in one or more values  
  *
  * @usage = $this->mongo_db->where_or('foo', array( 'foo', 'bar', 'blegh' );
  */ 
  public function where_or($field = "", $values) { 
    $this->where_init($field); 
    $this->wheres[$field]['$or'] = $values; 
    return($this); 
  } 
  /**
  *
  * WHERE AND  *
  *
  * Get the documents where the elements match 
  the specified values *
  * @usage = $this->mongo_db->where_and( array ( 'foo' => 1, 'b' => 'someexample' );
  */ 
  public function where_and($elements_values = array()) { 
    foreach ((array)$elements_values as $element => $val) { 
      $this->wheres[$element] = $val; 
    } return($this); 
  } 
  /**
  *
  * WHERE MOD  *
  *
  * Get the documents where $field % $mod = $result *
  * @usage = $this->mongo_db->where_mod( 'foo', 10, 1 );
  */ 
  public function where_mod($field, $num, $result) { 
    $this->where_init($field); 
    $this->wheres[$field]['$mod'] = array($num, $result); 
    return($this); 
  } 
  /**   *    *  Where size *    *  *  Get the documents where the size of a field is in a given $size int *  *  @usage : $this->mongo_db->where_size('foo', 1)->get('foobar'); */ 
  public function where_size($field = "", $size = "") { 
    $this->_where_init($field); 
    $this->wheres[$field]['$size'] = $size; 
    return ($this); 
  } 
  /**
  *
  * LIKE PARAMETERS *
  *
  * Get the documents where the (string) value of 
  a $field is like a value. The defaults
  * allow for a case-insensitive search.   *
  * @param $flags  
  * Allows for the typical regular expression flags:
  *   i = case insensitive
  *   m = multiline
  *   x = can contain comments
  *   l = locale  
  *   s = dotall, "." matches everything, including newlines
  *   u = match unicode
  *
  * @param $enable_start_wildcard
  * If set to anything other than TRUE, a starting line character "^" will be prepended
  * to the search value, representing only searching for a value at the start of
  * a new line.
  *  * @param $enable_end_wildcard 
  * If set to anything other than TRUE, an ending line character "$" will be appended
  * to the search value, representing only searching for a value at the end of
  * a line.
  * 
  * @usage = $this->mongo_db->like('foo', 'bar', 'im', FALSE, TRUE);
  */ 
  public function like($field = "", $value = "", $flags = "i", $enable_start_wildcard = TRUE, $enable_end_wildcard = TRUE) { 
    $field = (string) trim($field); 
    $this->where_init($field); 
    $value = (string) trim($value); 
    $value = quotemeta($value); 
    if ($enable_start_wildcard !== TRUE) { 
      $value = "^" . $value; 
    } if ($enable_end_wildcard !== TRUE) { 
      $value .= "$"; 
    } $regex = "/$value/$flags"; 
    $this->wheres[$field] = new MongoRegex($regex); 
    return($this); 
  } 
  public function wheres($where){ 
    $this->wheres = $where; 
  } 
  /**
  *
  * ORDER BY PARAMETERS *
  *
  * Sort the documents based on the parameters passed.
  To set values to descending order,
  * you must pass values of either -1, FALSE,
  'desc', or 'DESC', else they will be
  * set to 1 (ASC).
  *
  * @usage = $this->mongo_db->where_between('foo', 20, 30);
  */ 
  public function order_by($fields = array()) { 
    if (!is_array($fields) || !count($fields)) return ; 
    foreach ($fields as $col => $val) { 
      if ($val == -1 || $val === FALSE || strtolower($val) == 'desc') { 
        $this->sorts[$col] = -1; 
      } else { 
        $this->sorts[$col] = 1; 
      } 
    } return($this); 
  } 
  /**
  *
  * LIMIT DOCUMENTS *
  *
  * Limit the result set to $x number of documents  *
  * @usage = $this->mongo_db->limit($x);
  */ 
  public function limit($x = 99999) { 
    if ($x !== NULL && is_numeric($x) && $x >= 1) { 
      $this->limit = (int) $x; 
    } return($this); 
  } 
  /**
  *
  * OFFSET DOCUMENTS   *
  *
  * Offset the result set to skip $x number of documents
  *
  * @usage = $this->mongo_db->offset($x);
  */ 
  public function offset($x = 0) { 
    if ($x !== NULL && is_numeric($x) && $x >= 1) { 
      $this->offset = (int) $x; 
    } return($this); 
  } 
  /**
  *
  * GET_WHERE  *
  *  
  * Get the documents based upon the passed parameters  *
  * @usage = $this->mongo_db->get_where('foo', array('bar' => 'something'));
  */ 
  public function get_where($collection = "", $where = array(), $limit = 99999, $orderby=array()) { 
    if (is_array($orderby) || !emptyempty($orderby)) { 
      $order_by = $this->order_by($order_by); 
    } 
    return($this->where($where)->limit($limit)->get($collection)); 
  } 
  public function selectA($collection = "", $limit = 99999, $orderby=array()) { 
    if(intval($limit)<1){ 
      $limit = 999999; 
    } 
    $order_by = $this->order_by($orderby); 
    $re = $this->limit($limit)->get($collection); 
    $this->clear(); 
    return (array)$re; 
  } 
  public function listinfo($collection = "", $orderby=array(), $page=1, $pagesize=12) { 
    $page = max(intval($page), 1); 
    $offset = $pagesize * ($page - 1); 
    $pagesizes = $offset + $pagesize; 
    $this->offset($offset); 
    $order_by = $this->order_by($orderby); 
    $re = $this->limit($pagesize)->get($collection); 
    $this->limit(999999); 
    $count = $this->count($collection); 
    $this->pages = pages($count, $page, $pagesize); 
    return (array)$re; 
  } 
  /**
  *
  * GET *
  *
  * Get the documents based upon the passed parameters  *
  * @usage = $this->mongo_db->get('foo', array('bar' => 'something'));
  */ 
  public function get($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("In order to retreive documents from MongoDB, a collection name must be passed", 500); 
    } $results = array(); 
    $documents = $this->db->{$collection}->find($this->wheres, $this->selects)->limit((int) $this->limit)->skip((int) $this->offset)->sort($this->sorts); 
    $returns = array(); 
    foreach ($documents as $doc): $returns[] = $doc; 
    endforeach; 
    return($returns); 
  } 
  public function getMy($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("In order to retreive documents from MongoDB, a collection name must be passed", 500); 
    } $results = array(); 
    $documents = $this->db->{$collection}->find($this->wheres, $this->selects)->limit((int) $this->limit)->skip((int) $this->offset)->sort($this->sorts); 
    $returns = array(); 
    foreach ($documents as $doc): $returns[] = $doc; 
    endforeach; 
    $this -> clear(); 
    return($returns); 
  } 
  /**
  *
  * COUNT  *
  *
  * Count the documents based upon the passed parameters *
  * @usage = $this->mongo_db->get('foo');
  */ 
  public function count($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("In order to retreive a count of documents from MongoDB, a collection name must be passed", 500); 
    } $count = $this->db->{$collection}->find($this->wheres)->limit((int) $this->limit)->skip((int) $this->offset)->count(); 
    $this->clear(); 
    return($count); 
  } 
  /**
  *
  * INSERT  *
  *
  * Insert a new document into the passed collection *
  * @usage = $this->mongo_db->insert('foo', $data = array());
  */ 
  public function insert($collection = "", $data = array(), $name='ID') { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection selected to insert into", 500); 
    } if (count($data) == 0 || !is_array($data)) { 
      $this->error("Nothing to insert into Mongo collection or insert is not an array", 500); 
    } try { 
    /**
      wxcity_base::load_sys_class('whtysqs','',0); 
      $mongoseq_class = new whtysqs('creaseidsqs');
      $re = $mongoseq_class->query("?name=" . $collection . "&opt=put&data=1");
    **/ 
      $re = put_sqs('list_mongo_creaseidsqs','1'); 
      if(is_numeric($re)){ 
        $re++; 
        $data[$name] = intval($re); 
      }else{ 
        $data[$name] = intval(time()); 
        //die('mongosqs error'); 
      } 
      $this->db->{$collection}->insert($data, array('fsync' => TRUE)); 
      $this->clear(); 
      return $data[$name]; 
    } catch (MongoCursorException $e) { 
      $this->error("Insert of data into MongoDB failed: {$e->getMessage()}", 500); 
    } 
  } 
  public function insertWithId($collection = "", $data = array()) { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection selected to insert into", 500); 
    } if (count($data) == 0 || !is_array($data)) { 
      $this->error("Nothing to insert into Mongo collection or insert is not an array", 500); 
    } try { 
      $this->db->{$collection}->insert($data, array('fsync' => TRUE)); 
      $this->clear(); 
      return 1; 
    } catch (MongoCursorException $e) { 
      $this->error("Insert of data into MongoDB failed: {$e->getMessage()}", 500); 
    } 
  } 
  /**
  *
  * UPDATE  *
  *
  * Update a document into the passed collection *
  * @usage = $this->mongo_db->update('foo', $data = array());
  */ 
  public function update($collection = "", $data = array()) { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection selected to update", 500); 
    } if (count($data) == 0 || !is_array($data)) { 
      $this->error("Nothing to update in Mongo collection or update is not an array", 500); 
    } try { 
      $this->db->{$collection}->update($this->wheres, array('$set' => $data), array('fsync' => TRUE, 'multiple' => FALSE)); 
      $this->clear(); 
      return(TRUE); 
    } catch (MongoCursorException $e) { 
      $this->error("Update of data into MongoDB failed: {$e->getMessage()}", 500); 
    } 
  } 
  /**
  *
  * UPDATE_ALL  *
  *
  * Insert a new document into the passed collection *
  * @usage = $this->mongo_db->update_all('foo', $data = array());
  */ 
  public function update_all($collection = "", $data = array()) { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection selected to update", 500); 
    } if (count($data) == 0 || !is_array($data)) { 
      $this->error("Nothing to update in Mongo collection or update is not an array", 500); 
    } try { 
      $this->db->{$collection}->update($this->wheres, array('$set' => $data), array('fsync' => TRUE, 'multiple' => TRUE)); 
      return(TRUE); 
    } catch (MongoCursorException $e) { 
      $this->error("Update of data into MongoDB failed: {$e->getMessage()}", 500); 
    } 
  } 
  /**
  *
  * DELETE  *
  *
  * delete document from the passed collection based upon certain criteria *
  * @usage = $this->mongo_db->delete('foo', $data = array());
  */ 
  public function delete($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection selected to delete from", 500); 
    } try { 
      $this->db->{$collection}->remove($this->wheres, array('fsync' => TRUE, 'justOne' => TRUE)); 
      $this->clear(); 
      return(TRUE); 
    } catch (MongoCursorException $e) { 
      $this->error("Delete of data into MongoDB failed: {$e->getMessage()}", 500); 
    } 
  } 
  /**
  *
  * DELETE_ALL  *
  *
  * Delete all documents from the passed collection based upon certain criteria
  *
  * @usage = $this->mongo_db->delete_all('foo', $data = array());
  */ 
  public function delete_all($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection selected to delete from", 500); 
    } try { 
      $this->db->{$collection}->remove($this->wheres, array('fsync' => TRUE, 'justOne' => FALSE)); 
      return(TRUE); 
    } catch (MongoCursorException $e) { 
      $this->error("Delete of data into MongoDB failed: {$e->getMessage()}", 500); 
    } 
  } 
  /**
  *
  * ADD_INDEX  *
  *
  * Ensure an index of the keys in a collection with optional parameters.
  To set values to descending order,
  * you must pass values of either -1, FALSE, 'desc', or 'DESC', else they will be
  * set to 1 (ASC). *
  * @usage = $this->mongo_db->add_index($collection, array('first_name' => 'ASC', 'last_name' => -1), array('unique' => TRUE));
  */ 
  public function add_index($collection = "", $keys = array(), $options = array()) { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection specified to add index to", 500); 
    } if (emptyempty($keys) || !is_array($keys)) { 
      $this->error("Index could not be created to MongoDB Collection because no keys were specified", 500); 
    } foreach ($keys as $col => $val) { 
      if ($val == -1 || $val === FALSE || strtolower($val) == 'desc') { 
        $keys[$col] = -1; 
      } else { 
        $keys[$col] = 1; 
      } 
    } if ($this->db->{$collection}->ensureIndex($keys, $options) == TRUE) { 
      $this->clear(); 
      return($this); 
    } else { 
      $this->error("An error occured when trying to add an index to MongoDB Collection", 500); 
    } 
  } 
  /**
  *
  * REMOVE_INDEX   *
  *
  * Remove an index of the keys in a collection.
  To set values to descending order,
  * you must pass values of either -1, FALSE, 'desc', or 'DESC', else they will be
  * set to 1 (ASC). *
  * @usage = $this->mongo_db->remove_index($collection, array('first_name' => 'ASC', 'last_name' => -1));
  */ 
  public function remove_index($collection = "", $keys = array()) { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection specified to remove index from", 500); 
    } if (emptyempty($keys) || !is_array($keys)) { 
      $this->error("Index could not be removed from MongoDB Collection because no keys were specified", 500); 
    } if ($this->db->{$collection}->deleteIndex($keys, $options) == TRUE) { 
      $this->clear(); 
      return($this); 
    } else { 
      $this->error("An error occured when trying to remove an index from MongoDB Collection", 500); 
    } 
  } 
  /**
  *
  * REMOVE_ALL_INDEXES  *
  *
  * Remove all indexes from a collection. *
  * @usage = $this->mongo_db->remove_all_index($collection);
  */ 
  public function remove_all_indexes($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection specified to remove all indexes from", 500); 
    } $this->db->{$collection}->deleteIndexes(); 
    $this->clear(); 
    return($this); 
  } 
  /**
  *
  * LIST_INDEXES   *
  *
  * Lists all indexes in a collection. *
  * @usage = $this->mongo_db->list_indexes($collection);
  */ 
  public function list_indexes($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection specified to remove all indexes from", 500); 
    } return($this->db->{$collection}->getIndexInfo()); 
  } 
  /**
  *
  * DROP COLLECTION *
  *
  * Removes the specified collection from the database.
  Be careful because this
  * can have some very large issues in production!
  */ 
  public function drop_collection($collection = "") { 
    if (emptyempty($collection)) { 
      $this->error("No Mongo collection specified to drop from database", 500); 
    } $this->db->{$collection}->drop(); 
    return TRUE; 
  } 
  /**
  *
  * CLEAR  *
  *
  * Resets the class variables to default settings
  */ 
  private function clear() { 
    $this->selects = array(); 
    $this->wheres = array(); 
    $this->limit = NULL; 
    $this->offset = NULL; 
    $this->sorts = array(); 
  } 
  /**
  *
  * WHERE INITIALIZER  *
  *
  * Prepares parameters for insertion in $wheres array().
  */ 
  private function where_init($param) { 
    if (!isset($this->wheres[$param])) { 
      $this->wheres[$param] = array(); 
    } 
  } 
  public function error($str, $t) { 
    echo $str; 
    exit; 
  } 
} 
?>

使用范例:

$table_name=trim(strtolower($this->table_name)); 
$this->mongo_db->where($where); 
$order=!emptyempty($order)?array('AID'=>'DESC'):array('AID'=>'ASC');
//升序降序 
$infos=$this->mongo_db->listinfo($table_name,$order,$page,$pagesize);

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

PHP 相关文章推荐
一段php加密解密的代码
Oct 09 PHP
php curl 登录163邮箱并抓取邮箱好友列表的代码(经测试)
Apr 07 PHP
七款最流行的PHP本地服务器分享
Feb 19 PHP
使用swoole扩展php websocket示例
Feb 13 PHP
PHP实现的英文名字全拼随机排号脚本
Jul 04 PHP
用HTML/JS/PHP方式实现页面延时跳转的简单实例
Jul 18 PHP
PHP实现二维数组根据key进行排序的方法
Dec 30 PHP
基于PHP的加载类操作以及其他两种魔术方法的应用实例
Aug 28 PHP
PHP实现的curl批量请求操作示例
Jun 06 PHP
PHP lcfirst()函数定义与用法
Mar 08 PHP
php使用socket调用http和smtp协议实例小结
Jul 26 PHP
基于PHP的登录和注册的功能的实现
Aug 06 PHP
PHP中判断文件存在使用is_file还是file_exists?
Apr 03 #PHP
php专用数组排序类ArraySortUtil用法实例
Apr 03 #PHP
Win7下手动安装apache2.2、php5.4笔记
Apr 03 #PHP
PHP中返回引用类型的方法
Apr 03 #PHP
PHP中应该避免使用同名变量(拆分临时变量)
Apr 03 #PHP
PHP5多态性与动态绑定介绍
Apr 03 #PHP
php5.4以上版本GBK编码下htmlspecialchars输出为空问题解决方法汇总
Apr 03 #PHP
You might like
两个开源的Php输出Excel文件类
2010/02/08 PHP
php urlencode()与urldecode()函数字符编码原理详解
2011/12/06 PHP
PHP实现懒加载的方法
2015/03/07 PHP
Codeigniter检测表单post数据的方法
2015/03/21 PHP
PHP实现二叉树深度优先遍历(前序、中序、后序)和广度优先遍历(层次)实例详解
2018/04/20 PHP
短信提示使用 特效
2007/01/19 Javascript
利用JavaScript实现新闻滚动效果(实例代码)
2013/11/27 Javascript
Select标签下拉列表二级联动级联实例代码
2014/02/07 Javascript
JavaScript中的数值范围介绍
2014/12/29 Javascript
深入探讨javascript中的数据类型
2015/03/04 Javascript
JavaScript实现基于十进制的四舍五入实例
2015/07/17 Javascript
每日十条JavaScript经验技巧(一)
2016/06/23 Javascript
全面了解JavaScript对象进阶
2016/07/19 Javascript
jQuery实现表格隔行及滑动,点击时变色的方法【测试可用】
2016/08/20 Javascript
原生js实现倒计时--2018
2017/02/21 Javascript
详解vuelidate 对于vueJs2.0的验证解决方案
2017/03/09 Javascript
Node对CommonJS的模块规范
2019/11/06 Javascript
Vue循环遍历选项赋值到对应控件的实现方法
2020/06/22 Javascript
基于vue中的scoped坑点解说
2020/09/04 Javascript
vue使用exif获取图片经纬度的示例代码
2020/12/11 Vue.js
Python中设置变量作为默认值时容易遇到的错误
2015/04/03 Python
python实现多线程的两种方式
2016/05/22 Python
Python使用defaultdict读取文件各列的方法
2017/05/11 Python
python和mysql交互操作实例详解【基于pymysql库】
2019/06/04 Python
在Python中合并字典模块ChainMap的隐藏坑【推荐】
2019/06/27 Python
Jupyter安装拓展nbextensions及解决官网下载慢的问题
2021/03/03 Python
浅谈CSS3特性查询(Feature Query: @supports)功能简介
2017/07/31 HTML / CSS
英国最大的高品质珠宝和手表专家:Goldsmiths
2017/03/11 全球购物
全球第二大家装零售商:Lowe’s
2018/01/13 全球购物
西式结婚主持词
2014/03/14 职场文书
社区维稳工作方案
2014/06/06 职场文书
神农溪导游词
2015/02/11 职场文书
数学教师求职信范文
2015/03/20 职场文书
Python代码,能玩30多款童年游戏!这些有几个是你玩过的
2021/04/27 Python
解决golang 关于全局变量的坑
2021/05/06 Golang
golang实现浏览器导出excel文件功能
2022/03/25 Golang