MongoDB PHP数据库查询类

本文涉及的产品
云数据库 MongoDB,独享型 2核8GB
推荐场景:
构建全方位客户视图
简介:
Java代码   收藏代码
  1. <?php    
  2. /*** Mongodb类** examples:    
  3. * $mongo = new HMongodb("127.0.0.1:11223");  
  4. * $mongo->selectDb("test_db");  
  5. * 创建索引  
  6. * $mongo->ensureIndex("test_table", array("id"=>1), array('unique'=>true));  
  7. * 获取表的记录  
  8. * $mongo->count("test_table");  
  9. * 插入记录  
  10. * $mongo->insert("test_table", array("id"=>2, "title"=>"asdqw"));  
  11. * 更新记录  
  12. * $mongo->update("test_table", array("id"=>1),array("id"=>1,"title"=>"bbb"));  
  13. * 更新记录-存在时更新,不存在时添加-相当于set  
  14. * $mongo->update("test_table", array("id"=>1),array("id"=>1,"title"=>"bbb"),array("upsert"=>1));  
  15. * 查找记录  
  16. * $mongo->find("c", array("title"=>"asdqw"), array("start"=>2,"limit"=>2,"sort"=>array("id"=>1)))  
  17. * 查找一条记录  
  18. * $mongo->findOne("$mongo->findOne("ttt", array("id"=>1))", array("id"=>1));  
  19. * 删除记录  
  20. * $mongo->remove("ttt", array("title"=>"bbb"));  
  21. * 仅删除一条记录  
  22. * $mongo->remove("ttt", array("title"=>"bbb"), array("justOne"=>1));  
  23. * 获取Mongo操作的错误信息  
  24. * $mongo->getError();  
  25. */    
  26.     
  27. class HMongodb {    
  28.     
  29.     //Mongodb连接    
  30.     var $mongo;    
  31.     
  32.     var $curr_db_name;    
  33.     var $curr_table_name;    
  34.     var $error;    
  35.     
  36.     /**  
  37.     * 构造函数  
  38.     * 支持传入多个mongo_server(1.一个出问题时连接其它的server 2.自动将查询均匀分发到不同server)  
  39.     *  
  40.     * 参数:  
  41.     * $mongo_server:数组或字符串-array("127.0.0.1:1111", "127.0.0.1:2222")-"127.0.0.1:1111"  
  42.     * $connect:初始化mongo对象时是否连接,默认连接  
  43.     * $auto_balance:是否自动做负载均衡,默认是  
  44.     *  
  45.     * 返回值:  
  46.     * 成功:mongo object  
  47.     * 失败:false  
  48.     */    
  49.     function __construct($mongo_server, $connect=true, $auto_balance=true)    
  50.     {    
  51.         if (is_array($mongo_server))    
  52.         {    
  53.             $mongo_server_num = count($mongo_server);    
  54.             if ($mongo_server_num > 1 && $auto_balance)    
  55.             {    
  56.                 $prior_server_num = rand(1, $mongo_server_num);    
  57.                 $rand_keys = array_rand($mongo_server,$mongo_server_num);    
  58.                 $mongo_server_str = $mongo_server[$prior_server_num-1];    
  59.                 foreach ($rand_keys as $key)    
  60.                 {    
  61.                     if ($key != $prior_server_num - 1)    
  62.                     {    
  63.                         $mongo_server_str .= ',' . $mongo_server[$key];    
  64.                     }    
  65.                 }    
  66.             }    
  67.             else    
  68.             {    
  69.                 $mongo_server_str = implode(',', $mongo_server);    
  70.             }                  }    
  71.         else    
  72.         {    
  73.             $mongo_server_str = $mongo_server;    
  74.         }    
  75.         try {    
  76.             $this->mongo = new Mongo($mongo_server, array('connect'=>$connect));    
  77.         }    
  78.         catch (MongoConnectionException $e)    
  79.         {    
  80.             $this->error = $e->getMessage();    
  81.             return false;    
  82.         }    
  83.     }    
  84.     
  85.     function getInstance($mongo_server, $flag=array())    
  86.     {    
  87.         static $mongodb_arr;    
  88.         if (emptyempty($flag['tag']))    
  89.         {    
  90.             $flag['tag'] = 'default';          }    
  91.         if (isset($flag['force']) && $flag['force'] == true)    
  92.         {    
  93.             $mongo = new HMongodb($mongo_server);    
  94.             if (emptyempty($mongodb_arr[$flag['tag']]))    
  95.             {    
  96.                 $mongodb_arr[$flag['tag']] = $mongo;    
  97.             }    
  98.             return $mongo;    
  99.         }    
  100.         else if (isset($mongodb_arr[$flag['tag']]) && is_resource($mongodb_arr[$flag['tag']]))    
  101.         {    
  102.             return $mongodb_arr[$flag['tag']];    
  103.         }    
  104.         else    
  105.         {    
  106.             $mongo = new HMongodb($mongo_server);    
  107.             $mongodb_arr[$flag['tag']] = $mongo;    
  108.             return $mongo;                  }          }    
  109.     
  110.     /**  
  111.     * 连接mongodb server  
  112.     *  
  113.     * 参数:无  
  114.     *  
  115.     * 返回值:  
  116.     * 成功:true  
  117.     * 失败:false  
  118.     */    
  119.     function connect()    
  120.     {    
  121.         try {    
  122.             $this->mongo->connect();    
  123.             return true;    
  124.         }    
  125.         catch (MongoConnectionException $e)    
  126.         {    
  127.             $this->error = $e->getMessage();    
  128.             return false;    
  129.         }    
  130.     }    
  131.     
  132.     /**  
  133.     * select db  
  134.     *  
  135.     * 参数:$dbname  
  136.     *  
  137.     * 返回值:无  
  138.     */    
  139.     function selectDb($dbname)    
  140.     {    
  141.         $this->curr_db_name = $dbname;    
  142.     }    
  143.     
  144.     /**  
  145.     * 创建索引:如索引已存在,则返回。  
  146.     *  
  147.     * 参数:  
  148.     * $table_name:表名  
  149.     * $index:索引-array("id"=>1)-在id字段建立升序索引  
  150.     * $index_param:其它条件-是否唯一索引等  
  151.     *  
  152.     * 返回值:  
  153.     * 成功:true  
  154.     * 失败:false  
  155.     */    
  156.     function ensureIndex($table_name, $index, $index_param=array())    
  157.     {    
  158.         $dbname = $this->curr_db_name;    
  159.         $index_param['safe'] = 1;    
  160.         try {    
  161.             $this->mongo->$dbname->$table_name->ensureIndex($index, $index_param);    
  162.             return true;    
  163.         }    
  164.         catch (MongoCursorException $e)    
  165.         {    
  166.             $this->error = $e->getMessage();    
  167.             return false;    
  168.         }    
  169.     }    
  170.     
  171.     /**  
  172.     * 插入记录  
  173.     *  
  174.     * 参数:  
  175.     * $table_name:表名  
  176.     * $record:记录  
  177.     *  
  178.     * 返回值:  
  179.     * 成功:true  
  180.     * 失败:false  
  181.     */    
  182.     function insert($table_name, $record)    
  183.     {    
  184.         $dbname = $this->curr_db_name;    
  185.         try {    
  186.             $this->mongo->$dbname->$table_name->insert($record, array('safe'=>true));    
  187.             return true;    
  188.         }    
  189.         catch (MongoCursorException $e)    
  190.         {    
  191.             $this->error = $e->getMessage();    
  192.             return false;    
  193.         }    
  194.     }    
  195.     
  196.     /**  
  197.     * 查询表的记录数  
  198.     *  
  199.     * 参数:  
  200.     * $table_name:表名  
  201.     *  
  202.     * 返回值:表的记录数  
  203.     */    
  204.     function count($table_name)    
  205.     {    
  206.         $dbname = $this->curr_db_name;    
  207.         return $this->mongo->$dbname->$table_name->count();    
  208.     }    
  209.     
  210.     /**  
  211.     * 更新记录  
  212.     *  
  213.     * 参数:  
  214.     * $table_name:表名  
  215.     * $condition:更新条件  
  216.     * $newdata:新的数据记录  
  217.     * $options:更新选择-upsert/multiple  
  218.     *  
  219.     * 返回值:  
  220.     * 成功:true  
  221.     * 失败:false  
  222.     */    
  223.     function update($table_name, $condition, $newdata, $options=array())    
  224.     {    
  225.         $dbname = $this->curr_db_name;    
  226.         $options['safe'] = 1;    
  227.         if (!isset($options['multiple']))    
  228.         {    
  229.             $options['multiple'] = 0;          }    
  230.         try {    
  231.             $this->mongo->$dbname->$table_name->update($condition, $newdata, $options);    
  232.             return true;    
  233.         }    
  234.         catch (MongoCursorException $e)    
  235.         {    
  236.             $this->error = $e->getMessage();    
  237.             return false;    
  238.         }          }    
  239.     
  240.     /**  
  241.     * 删除记录  
  242.     *  
  243.     * 参数:  
  244.     * $table_name:表名  
  245.     * $condition:删除条件  
  246.     * $options:删除选择-justOne  
  247.     *  
  248.     * 返回值:  
  249.     * 成功:true  
  250.     * 失败:false  
  251.     */    
  252.     function remove($table_name, $condition, $options=array())    
  253.     {    
  254.         $dbname = $this->curr_db_name;    
  255.         $options['safe'] = 1;    
  256.         try {    
  257.             $this->mongo->$dbname->$table_name->remove($condition, $options);    
  258.             return true;    
  259.         }    
  260.         catch (MongoCursorException $e)    
  261.         {    
  262.             $this->error = $e->getMessage();    
  263.             return false;    
  264.         }          }    
  265.     
  266.     /**  
  267.     * 查找记录  
  268.     *  
  269.     * 参数:  
  270.     * $table_name:表名  
  271.     * $query_condition:字段查找条件  
  272.     * $result_condition:查询结果限制条件-limit/sort等  
  273.     * $fields:获取字段  
  274.     *  
  275.     * 返回值:  
  276.     * 成功:记录集  
  277.     * 失败:false  
  278.     */    
  279.     function find($table_name, $query_condition, $result_condition=array(), $fields=array())    
  280.     {    
  281.         $dbname = $this->curr_db_name;    
  282.         $cursor = $this->mongo->$dbname->$table_name->find($query_condition, $fields);    
  283.         if (!emptyempty($result_condition['start']))    
  284.         {    
  285.             $cursor->skip($result_condition['start']);    
  286.         }    
  287.         if (!emptyempty($result_condition['limit']))    
  288.         {    
  289.             $cursor->limit($result_condition['limit']);    
  290.         }    
  291.         if (!emptyempty($result_condition['sort']))    
  292.         {    
  293.             $cursor->sort($result_condition['sort']);    
  294.         }    
  295.         $result = array();    
  296.         try {    
  297.             while ($cursor->hasNext())    
  298.             {    
  299.                 $result[] = $cursor->getNext();    
  300.             }    
  301.         }    
  302.         catch (MongoConnectionException $e)    
  303.         {    
  304.             $this->error = $e->getMessage();    
  305.             return false;    
  306.         }    
  307.         catch (MongoCursorTimeoutException $e)    
  308.         {    
  309.             $this->error = $e->getMessage();    
  310.             return false;    
  311.         }    
  312.         return $result;    
  313.     }    
  314.     
  315.     /**  
  316.     * 查找一条记录  
  317.     *  
  318.     * 参数:  
  319.     * $table_name:表名  
  320.     * $condition:查找条件  
  321.     * $fields:获取字段  
  322.     *  
  323.     * 返回值:  
  324.     * 成功:一条记录  
  325.     * 失败:false  
  326.     */    
  327.     function findOne($table_name, $condition, $fields=array())    
  328.     {    
  329.         $dbname = $this->curr_db_name;    
  330.         return $this->mongo->$dbname->$table_name->findOne($condition, $fields);    
  331.     }    
  332.     
  333.     /**  
  334.     * 获取当前错误信息  
  335.     *  
  336.     * 参数:无  
  337.     *  
  338.     * 返回值:当前错误信息  
  339.     */    
  340.     function getError()    
  341.     {    
  342.         return $this->error;    
  343.     }    
  344. }    
  345.     
  346. ?>  

数据库连接

Java代码   收藏代码
  1. //⑴默认格式  
  2. $m = new Mongo();  
  3. //这里采用默认连接本机的27017端口,当然你也可以连接远程主机如192.168.0.4:27017,如果端口是27017,端口可以省略  
  4. //⑵标准连接  
  5. $m = new Mongo("mongodb://${username}:${password}@localhost");   

选择想要的collection:

Java代码   收藏代码
  1. $mo = new Mongo();  
  2. $coll = $mo->selectCollection('db''mycoll');//得到一个collection对象  

插入数据(MongoCollection对象)

Java代码   收藏代码
  1. $coll = $mo->db->foo;  
  2. $a = array('a' => 'b');  
  3. $options = array('safe' => true);  
  4. $rs = $coll->insert($a, $options);  

更新数据库中的记录(MongoCollection对象)

Java代码   收藏代码
  1. $coll = $mo->db->coll;  
  2. $c = array('a' => 1's' => array('$lt' => 100));  
  3. $newobj = array('e' => 'f''x' => 'y');  
  4. $options = array('safe' => true'multiple' => true);  
  5. $rs = $coll->update($c, $newobj, $options);  

删除数据库中的记录(MongoCollection对象)

Java代码   收藏代码
  1. $coll = $mo->db->coll;  
  2. $c = array('a' => 1's' => array('$lt' => 100));  
  3. $options = array('safe' => true);  
  4. $rs = $coll->remove($c, $options);  

查询collection获得多条记录(MongoCollection类)

Java代码   收藏代码
  1. $coll = $mo->db->coll;  
  2. $query = array('s' => array('$lt' => 100));  
  3. $fields = array('a' => true'b' => true);  
  4. $rs = $coll->find($query, $fields);  

 查询collection获得单条记录(MongoCollection类)

Java代码   收藏代码
  1. $coll = $mo->db->coll;  
  2. $query = array('s' => array('$lt' => 100));  
  3. $fields = array('a' => true'b' => true);  
  4. $rs = $coll->findOne($query, $fields);  

针对游标对象MongoCursor的操作(MongoCursor类):

Java代码   收藏代码
  1. $cursor = $coll->find($query,$fields);  
  2. while($cursor->hasNext()){  
  3. $r = $cursor->getNext();  
  4.     var_dump($r);  
  5. }  
  6. //或者  
  7. $cursor = $coll->find($query,$fields);  
  8. foreache($cursor as $k=>$v){  
  9.     var_dump($v);  
  10. }  
  11. //或者  
  12. $cursor = $coll->find($query,$fields);  
  13. $array= iterator_to_array($cursor);  

删除一个数据库

Java代码   收藏代码
  1. $m -> dropDB("comedy");  

删除当前DB

Java代码   收藏代码
  1. $db = $mo->dbname;  
  2. $db->drop();  

列出所有可用数据库

Java代码   收藏代码
  1. $m->listDBs();   //无返回值  

获得当前数据库名

Java代码   收藏代码
  1. $db = $mo->dbname;  
  2. $db->_tostring();  
相关实践学习
MongoDB数据库入门
MongoDB数据库入门实验。
快速掌握 MongoDB 数据库
本课程主要讲解MongoDB数据库的基本知识,包括MongoDB数据库的安装、配置、服务的启动、数据的CRUD操作函数使用、MongoDB索引的使用(唯一索引、地理索引、过期索引、全文索引等)、MapReduce操作实现、用户管理、Java对MongoDB的操作支持(基于2.x驱动与3.x驱动的完全讲解)。 通过学习此课程,读者将具备MongoDB数据库的开发能力,并且能够使用MongoDB进行项目开发。 &nbsp; 相关的阿里云产品:云数据库 MongoDB版 云数据库MongoDB版支持ReplicaSet和Sharding两种部署架构,具备安全审计,时间点备份等多项企业能力。在互联网、物联网、游戏、金融等领域被广泛采用。 云数据库MongoDB版(ApsaraDB for MongoDB)完全兼容MongoDB协议,基于飞天分布式系统和高可靠存储引擎,提供多节点高可用架构、弹性扩容、容灾、备份回滚、性能优化等解决方案。 产品详情: https://www.aliyun.com/product/mongodb
相关文章
|
13天前
|
存储 JSON NoSQL
学习 MongoDB:打开强大的数据库技术大门
MongoDB 是一个基于分布式文件存储的文档数据库,由 C++ 编写,旨在为 Web 应用提供可扩展的高性能数据存储解决方案。它与 MySQL 类似,但使用文档结构而非表结构。核心概念包括:数据库(Database)、集合(Collection)、文档(Document)和字段(Field)。MongoDB 使用 BSON 格式存储数据,支持多种数据类型,如字符串、整数、数组等,并通过二进制编码实现高效存储和传输。BSON 文档结构类似 JSON,但更紧凑,适合网络传输。
48 15
|
21天前
|
存储 NoSQL 关系型数据库
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板
我们的风控系统引入阿里云数据库MongoDB版后,解决了特征类字段灵活加减的问题,大大提高了开发效率,极大的提升了业务用户体验,获得了非常好的效果
阿里云数据库MongoDB版助力信也科技 打造互联网金融企业样板
|
29天前
|
存储 缓存 网络协议
数据库执行查询请求的过程?
客户端发起TCP连接请求,服务端通过连接器验证主机信息、用户名及密码,验证通过后创建专用进程处理交互。服务端进程缓存以减少创建和销毁线程的开销。后续步骤包括缓存查询(8.0版后移除)、语法解析、查询优化及存储引擎调用,最终返回查询结果。
29 6
|
2月前
|
SQL 存储 BI
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
gbase 8a 数据库 SQL合并类优化——不同数据统计周期合并为一条SQL语句
|
2月前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
63 4
|
27天前
|
SQL JavaScript 程序员
数据库LIKE查询屡试不爽?揭秘大多数人都忽视的秘密操作符!
本文分析了因数据库中的不可见空白字符导致的数据查询问题,探讨了问题的成因与特性,并提出了使用 SQL 语句修复问题的有效方案。同时,总结了避免类似问题的经验和注意事项。
31 0
|
2月前
|
存储 缓存 固态存储
怎么让数据库查询更快
【10月更文挑战第28天】
41 2
|
2月前
|
存储 缓存 关系型数据库
怎么让数据库查询更快
【10月更文挑战第25天】通过以上综合的方法,可以有效地提高数据库查询的速度,提升应用程序的性能和响应速度。但在优化过程中,需要根据具体的数据库系统、应用场景和数据特点进行合理的调整和测试,以找到最适合的优化方案。
|
2月前
|
JSON JavaScript 关系型数据库
node.js连接GBase 8a 数据库 并进行查询代码示例
node.js连接GBase 8a 数据库 并进行查询代码示例
|
2月前
|
监控 关系型数据库 MySQL
数据库优化:MySQL索引策略与查询性能调优实战
【10月更文挑战第27天】本文深入探讨了MySQL的索引策略和查询性能调优技巧。通过介绍B-Tree索引、哈希索引和全文索引等不同类型,以及如何创建和维护索引,结合实战案例分析查询执行计划,帮助读者掌握提升查询性能的方法。定期优化索引和调整查询语句是提高数据库性能的关键。
342 1