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教程
yii2.0框架数据库操作简单示例【添加,修改,删除,查询,打印
这篇文章主要介绍了yii2.0框架数据库操作,结合简单实例形式分析了yii2.0框架数据库添加,修改,删除,查询,打印等相关操作技巧,需要的朋友可以参考下...
- PHP教程
PHP将DateTime对象转化为友好时间显示的实现代码
PHP将DateTime对象转化为友好时间显示的实现代码,需要的朋友可以参考下。 ...
- PHP教程
PHP图像识别技术原理与实现
本篇文章主要介绍了PHP图像识别技术原理与实现,这个平时做的密码验证有异曲同工之处,有需要的可以了解一下。...
- PHP教程
php 删除cookie方法详解
本文简单介绍了关于php删除cookie的方法,就是设置cookie有效期或者为空,非常实用的小技巧,这里推荐给大家。...
- PHP教程
php在数据库抽象层简单使用PDO的方法
这篇文章主要介绍了php在数据库抽象层简单使用PDO的方法,以PDO针对数据库的连接、插入、查询等操作为例分析了PDO操作数据库的相关技巧,需要的朋友可以...
- PHP教程
使用php完成常见的文件上传功能(推荐)
文件上传功能在开发过程中是非常常见的功能,可以上传文件也可以上传头像等,不同的浏览器文件上传有不同的效果,下面通过本文给大家分享使用php完...
- PHP教程
ThinkPHP框架实现的邮箱激活功能示例
这篇文章主要介绍了ThinkPHP框架实现的邮箱激活功能,结合实例形式分析了thinkPHP使用class.smtp.php及class.phpmailer.php类文件进行邮件发送实现激活功能的具体操...
- PHP教程
php远程下载类分享
这篇文章主要为大家分享了php远程下载类,用户可以将下载文件到主机,感兴趣的小伙伴们可以参考一下...