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教程
CodeIgniter记录错误日志的方法全面总结
这篇文章主要介绍了CodeIgniter记录错误日志的方法,详细分析了CodeIgniter框架的文件结构与相应的功能,结合实例分析了CodeIgniter框架记录错误日志的实现技巧...
- PHP教程
PHP面向对象详解(三)
这篇文章主要介绍了PHP面向对象详解(三) 的相关资料,需要的朋友可以参考下...
- PHP教程
php curl_init函数用法
使用PHP的cURL库可以简单和有效地去抓网页。你只需要运行一个脚本,然后分析一下你所抓取的网页,然后就可以以程序的方式得到你想要的数据了 ...
- PHP教程
laravel 输出最后执行sql 附:whereIn的使用方法
今天小编就为大家分享一篇laravel 输出最后执行sql 附:whereIn的使用方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...
- PHP教程
php eval函数用法 PHP中eval()函数小技巧
本函式可将字符串之中的变量值代入,通常用在处理数据库的数据上 ...
- PHP教程
Linux平台PHP5.4设置FPM线程数量的方法
这篇文章主要介绍了Linux平台PHP5.4设置FPM线程数量的方法,较为详细的分析了Linux平台php5.4设置FPM的相关参数、功能及使用技巧,需要的朋友可以参考下...
- PHP教程
php比较两个指定的日期的实例讲解
在本篇文章里小编给大家整理了一篇关于php如何比较两个指定的日期的相关知识点内容,有需要的朋友们可以参考下。...
- PHP教程
PHP编程中的Session阻塞问题与解决方法分析
这篇文章主要介绍了PHP编程中的Session阻塞问题与解决方法,简单分析了php session阻塞的原理、原因与简单解决方法,需要的朋友可以参考下...