1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
|
class HMongodb { private $mongo ; //Mongodb连接 private $curr_db_name ; private $curr_table_name ; private $error ; public function getInstance( $mongo_server , $flag = array ()) { static $mongodb_arr ; if ( empty ( $flag [ 'tag' ])) { $flag [ 'tag' ] = 'default' ; } if (isset( $flag [ 'force' ]) && $flag [ 'force' ] == true) { $mongo = new HMongodb( $mongo_server ); if ( empty ( $mongodb_arr [ $flag [ 'tag' ]])) { $mongodb_arr [ $flag [ 'tag' ]] = $mongo ; } return $mongo ; } else if (isset( $mongodb_arr [ $flag [ 'tag' ]]) && is_resource ( $mongodb_arr [ $flag [ 'tag' ]])) { return $mongodb_arr [ $flag [ 'tag' ]]; } else { $mongo = new HMongodb( $mongo_server ); $mongodb_arr [ $flag [ 'tag' ]] = $mongo ; return $mongo ; } } /** * 构造函数 * 支持传入多个mongo_server(1.一个出问题时连接其它的server 2.自动将查询均匀分发到不同server) * * 参数: * $mongo_server:数组或字符串-array("127.0.0.1:1111", "127.0.0.1:2222")-"127.0.0.1:1111" * $connect:初始化mongo对象时是否连接,默认连接 * $auto_balance:是否自动做负载均衡,默认是 * * 返回值: * 成功:mongo object * 失败:false */ private function __construct( $mongo_server , $connect =true, $auto_balance =true) { if ( is_array ( $mongo_server )) { $mongo_server_num = count ( $mongo_server ); if ( $mongo_server_num > 1 && $auto_balance ) { $prior_server_num = rand(1, $mongo_server_num ); $rand_keys = array_rand ( $mongo_server , $mongo_server_num ); $mongo_server_str = $mongo_server [ $prior_server_num -1]; foreach ( $rand_keys as $key ) { if ( $key != $prior_server_num - 1) { $mongo_server_str .= ',' . $mongo_server [ $key ]; } } } else { $mongo_server_str = implode( ',' , $mongo_server ); } } else { $mongo_server_str = $mongo_server ; } try { $this ->mongo = new Mongo( $mongo_server , array ( 'connect' => $connect )); } catch (MongoConnectionException $e ) { $this ->error = $e ->getMessage(); return false; } } /** * 连接mongodb server * * 参数:无 * * 返回值: * 成功:true * 失败:false */ public function connect() { try { $this ->mongo->connect(); return true; } catch (MongoConnectionException $e ) { $this ->error = $e ->getMessage(); return false; } } /** * select db * * 参数:$dbname * * 返回值:无 */ public function selectDb( $dbname ) { $this ->curr_db_name = $dbname ; } /** * 创建索引:如索引已存在,则返回。 * * 参数: * $table_name:表名 * $index:索引-array("id"=>1)-在id字段建立升序索引 * $index_param:其它条件-是否唯一索引等 * * 返回值: * 成功:true * 失败:false */ public function ensureIndex( $table_name , $index , $index_param = array ()) { $dbname = $this ->curr_db_name; $index_param [ 'safe' ] = 1; try { $this ->mongo-> $dbname -> $table_name ->ensureIndex( $index , $index_param ); return true; } catch (MongoCursorException $e ) { $this ->error = $e ->getMessage(); return false; } } /** * 插入记录 * * 参数: * $table_name:表名 * $record:记录 * * 返回值: * 成功:true * 失败:false */ public function insert( $table_name , $record ) { $dbname = $this ->curr_db_name; try { $this ->mongo-> $dbname -> $table_name ->insert( $record , array ( 'safe' =>true)); return true; } catch (MongoCursorException $e ) { $this ->error = $e ->getMessage(); return false; } } /** * 查询表的记录数 * * 参数: * $table_name:表名 * * 返回值:表的记录数 */ public function count ( $table_name ) { $dbname = $this ->curr_db_name; return $this ->mongo-> $dbname -> $table_name -> count (); } /** * 更新记录 * * 参数: * $table_name:表名 * $condition:更新条件 * $newdata:新的数据记录 * $options:更新选择-upsert/multiple * * 返回值: * 成功:true * 失败:false */ public function update( $table_name , $condition , $newdata , $options = array ()) { $dbname = $this ->curr_db_name; $options [ 'safe' ] = 1; if (!isset( $options [ 'multiple' ])) { $options [ 'multiple' ] = 0; } try { $this ->mongo-> $dbname -> $table_name ->update( $condition , $newdata , $options ); return true; } catch (MongoCursorException $e ) { $this ->error = $e ->getMessage(); return false; } } /** * 删除记录 * * 参数: * $table_name:表名 * $condition:删除条件 * $options:删除选择-justOne * * 返回值: * 成功:true * 失败:false */ public function remove( $table_name , $condition , $options = array ()) { $dbname = $this ->curr_db_name; $options [ 'safe' ] = 1; try { $this ->mongo-> $dbname -> $table_name ->remove( $condition , $options ); return true; } catch (MongoCursorException $e ) { $this ->error = $e ->getMessage(); return false; } } /** * 查找记录 * * 参数: * $table_name:表名 * $query_condition:字段查找条件 * $result_condition:查询结果限制条件-limit/sort等 * $fields:获取字段 * * 返回值: * 成功:记录集 * 失败:false */ public function find( $table_name , $query_condition , $result_condition = array (), $fields = array ()) { $dbname = $this ->curr_db_name; $cursor = $this ->mongo-> $dbname -> $table_name ->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 (MongoConnectionException $e ) { $this ->error = $e ->getMessage(); return false; } catch (MongoCursorTimeoutException $e ) { $this ->error = $e ->getMessage(); return false; } return $result ; } /** * 查找一条记录 * * 参数: * $table_name:表名 * $condition:查找条件 * $fields:获取字段 * * 返回值: * 成功:一条记录 * 失败:false */ public function findOne( $table_name , $condition , $fields = array ()) { $dbname = $this ->curr_db_name; return $this ->mongo-> $dbname -> $table_name ->findOne( $condition , $fields ); } /** * 获取当前错误信息 * * 参数:无 * * 返回值:当前错误信息 */ public function getError() { return $this ->error; } /*** Mongodb类** examples: * $mongo = new HMongodb("127.0.0.1:11223"); * $mongo->selectDb("test_db"); * 创建索引 * $mongo->ensureIndex("test_table", array("id"=>1), array('unique'=>true)); * 获取表的记录 * $mongo->count("test_table"); * 插入记录 * $mongo->insert("test_table", array("id"=>2, "title"=>"asdqw")); * 更新记录 * $mongo->update("test_table", array("id"=>1),array("id"=>1,"title"=>"bbb")); * 更新记录-存在时更新,不存在时添加-相当于set * $mongo->update("test_table", array("id"=>1),array("id"=>1,"title"=>"bbb"),array("upsert"=>1)); * 查找记录 * $mongo->find("c", array("title"=>"asdqw"), array("start"=>2,"limit"=>2,"sort"=>array("id"=>1))) * 查找一条记录 * $mongo->findOne("$mongo->findOne("ttt", array("id"=>1))", array("id"=>1)); * 删除记录 * $mongo->remove("ttt", array("title"=>"bbb")); * 仅删除一条记录 * $mongo->remove("ttt", array("title"=>"bbb"), array("justOne"=>1)); * 获取Mongo操作的错误信息 * $mongo->getError(); */ } |
PHP实现的MongoDB数据库操作类分享
2020-06-29 13:49服务器之家 PHP教程
这篇文章主要介绍了PHP实现的MongoDB数据库操作类分享,模板mysql版的操作类,需要的朋友可以参考下
延伸 · 阅读
- 2022-03-10Mongodb数据库转换为表格文件的库
- 2022-03-10简单谈谈centos7中配置php
- 2022-03-10C/C++ Qt 数据库与TreeView组件绑定详解
- 2022-03-09MySQL数据库如何给表设置约束详解
- 2022-03-09MySQL数据库触发器从小白到精通
- 2022-03-09Linux中无法远程连接数据库问题的解决方法
- PHP教程
PHP设计模式之迭代器模式Iterator实例分析【对象行为型】
这篇文章主要介绍了PHP设计模式之迭代器模式Iterator,结合实例形式分析了PHP迭代器模式Iterator相关概念、原理、实现方法与操作注意事项,需要的朋友可以参...
- PHP教程
php 数组元素快速去重
本篇文章主要介绍了php数组元素快速去重的方法,具有很好的参考价值。下面跟着小编一起来看下吧...
- PHP教程
Laravel框架使用Redis的方法详解
这篇文章主要介绍了Laravel框架使用Redis的方法,结合实例形式较为详细的分析了Laravel框架中Redis数据库配置、使用方法及相关操作注意事项,需要的朋友可以...
- PHP教程
PHP中使用匿名函数操作数据库的例子
这篇文章主要介绍了PHP中使用匿名函数操作数据库的例子,本文直接给出类的代码、使用例子、继承例子,需要的朋友可以参考下...
- PHP教程
PHP基于php_imagick_st-Q8.dll实现JPG合成GIF图片的方法
这篇文章主要介绍了PHP基于php_imagick_st-Q8.dll实现JPG合成GIF图片的方法,需要的朋友可以参考下 ...
- PHP教程
eclipse php wamp配置教程
这篇文章主要为大家详细介绍了eclipse php wamp配置教程,极其简单的php入门教程,感兴趣的小伙伴们可以参考一下...
- PHP教程
PHP里8个鲜为人知的安全函数分析
这篇文章主要介绍了PHP里8个鲜为人知的安全函数,较为详细的分析了addslashes、htmlentities、htmlspecialchars及md5等函数在PHP程序设计安全中所起到重要作用,非常...
- PHP教程
PHP之使用swoole统计在线人数和ID案例讲解
这篇文章主要介绍了PHP之使用swoole统计在线人数和ID案例讲解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参...