本文实例讲述了PHP实现的mongoDB数据库操作类。分享给大家供大家参考,具体如下: 最近的项目开发中使用的数据库是mongodb数据库,因为小编的公司也是刚刚使用mongodb数据库,所以之前没有封装好的mongodb数据库操作类拿来使用,所以小编在项目中自己封装了一个mongodb数据库操作类,特拿出来分享,不尽人意的地方希望大家勿喷。 众所周知,mongodb是典型的nosql数据库的代表,受到很多开发者的追捧,近几年尤为火热,mongodb的流行不是没有原因的,下边给大家简单介绍下MongoDB。 MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。他支持的数据结构非常松散,是类似json的bjson格式,因此可以存储比较复杂的数据类型。Mongo最大的特点是他支持的查询语言非常强大,其语法有点类似于面向对象的查询语言,几乎可以实现类似关系数据库单表查询的绝大部分功能,而且还支持对数据建立索引。 它的特点是高性能、易部署、易使用,存储数据非常方便。主要功能特性有: 面向集合存储,易存储对象类型的数据。
9 p, u+ f7 a) B$ B) z模式自由。 `8 u- _* {/ b+ L
支持动态查询。. O! W& Y2 j1 j6 r
支持完全索引,包含内部对象。! {9 G) T. _/ _$ Z- ]
支持查询。7 _, F2 B8 `, H; p1 k
支持复制和故障恢复。
8 l" H/ G3 I/ i0 K使用高效的二进制数据存储,包括大型对象(如视频等)。) {' M. E& U! E/ L# x9 T* a% t
自动处理碎片,以支持云计算层次的扩展性
5 p: B7 ?2 x4 {4 |$ L+ }, n支持RUBY,PYTHON,JAVA,C++,PHP等多种语言。
5 r8 o* h4 q6 z文件存储格式为BSON(一种JSON的扩展)
7 [2 m% q7 p8 M B" g+ x8 f$ \可通过网络访问 所谓“面向集合”(Collenction-Orented),意思是数据被分组存储在数据集中,被称为一个集合(Collenction)。每个 集合在数据库中都有一个唯一的标识名,并且可以包含无限数目的文档。集合的概念类似关系型数据库(RDBMS)里的表(table),不同的是它不需要定 义任何模式(schema)。 模式自由(schema-free),意味着对于存储在mongodb数据库中的文件,我们不需要知道它的任何结构定义。如果需要的话,你完全可以把不同结构的文件存储在同一个数据库里。 存储在集合中的文档,被存储为键-值对的形式。键用于唯一标识一个文档,为字符串类型,而值则可以是各中复杂的文件类型。我们称这种存储形式为BSON(Binary Serialized dOcument Format)。 MongoDB服务端可运行在Linux、Windows或OS X平台,支持32位和64位应用,默认端口为27017。推荐运行在64位平台,因为MongoDB 在32位模式运行时支持的最大文件尺寸为2GB。 MongoDB把数据存储在文件中(默认路径为:/data/db),为提高效率使用内存映射文件进行管理。 小编自己封装的PHP操作MongoDB数据库的数据库操作类源码如下,仅供参考。 - <?php
$ _, ?! Q8 S7 S! A4 g6 j - /**9 I' Q! }8 d" I4 y" J
- * PHP操作mongodb数据库操作类
V, R7 |' ~) Q5 I7 m, r1 Z+ m - */
2 J$ Q, ~+ s- A: I - class Database {, j) c- B1 L8 {
- protected $database = '';
% E6 ?. J- F" I. T' c% [ - protected $mo;
. x1 }9 S! Y2 D% |) \ - /**" e, X- v+ }% \8 d' y7 }& U
- * 构造方法
% P. O" \4 C& d& U - */8 ], Q* P8 {* F/ ~5 u. u
- public function __construct() {* a" U0 a: ?8 h% w! L& F
- $server = DBSERVER;2 c0 v& u& F6 `, r6 E0 Y
- $user = DBUSER;8 J- S, ?$ r& T
- $password = DBPASS;$ w2 b- U6 T9 [! D, v
- $port = DBPORT;
6 f: J/ [" N% w q% [4 v5 V( h - $database = DBNAME;- {+ k; \. |+ K# M% F n
- $mongo = $this->getInstance($server, $user, $password, $port);0 I3 l1 B/ m- G' b0 E7 o
- $this->database = $mongo->$database;
4 \5 F7 T7 n, z0 Z - }
5 K2 ?! p9 ]9 O- p# H - /**
. G3 B6 x. U! Y- [5 G G7 N - * 数据库单例方法7 b% O+ `/ v- M1 B: Q, `' `
- * @param $server. A5 P8 \: o- R& A# h
- * @param $user$ I. f% J7 {) X. K. f
- * @param $password4 q8 ]$ I: R b# s9 w
- * @param $port3 c" `3 q$ h9 r) |
- * @return Mongo" g- ?" g* r7 }2 [; ? X) y
- */. ` b& O- f7 n$ i& z
- public function getInstance($server, $user, $password, $port) {6 k3 w4 `$ h. I
- if (isset($this->mo)) {
0 V8 J% H8 ^% a8 P* ~ - return $this->mo;
7 E8 P8 m, q, L - } else {
1 W1 Q+ g4 d8 y9 }$ N - if (!empty($server)) {3 a: E: `) A# w3 Z) J" d
- if (!empty($port)) {
/ _' G) z/ y7 J `2 P - if (!empty($user) && !empty($password)) {* {5 F5 w; ^* X7 k
- $this->mo = new Mongo("mongodb://{$user}:{$password}@{$server}:{$port}");/ D+ G" S9 r+ i) d; A/ b
- } else {. u4 g9 `3 q" f% ^9 w% S2 h
- $this->mo = new Mongo("mongodb://{$server}:{$port}");7 ~) | [: A" u
- }8 ^% k* C" O# m* I/ l
- } else {3 n/ D; w0 I" i! \" }( F
- $this->mo = new Mongo("mongodb://{$server}");' ~/ V3 M6 [% C& ]
- }( }' W/ S2 T! v* h: @
- } else {
/ ^6 s. G+ b; J7 [ - $this->mo = new Mongo();
: {3 ^: I$ ^; D - }% ]' t F( h! G/ d
- return $this->mo;
9 g% O! o" u9 @& N6 E% e% N7 O - }) J1 P2 J7 _* W( U
- }
+ R9 w. _' x! h' ~. P1 v$ ~' W1 N( L - /**8 p' D4 F1 D% n) ?8 ]
- * 查询表中所有数据3 L4 B0 f" K/ u& q
- * @param $table
8 m5 e8 W5 V7 o9 f6 ~& u! ^ o V - * @param array $where- b+ G: W! w( A4 ]
- * @param array $sort6 I) o; S* s- I3 l3 L
- * @param string $limit
z( P1 S2 r0 G# _ - * @param string $skip; D% X% ]/ L5 s4 ]
- * @return array|int
0 m+ n f( b" O$ r* l* J x! O1 C - */
# Z; T% j c2 t9 J - public function getAll($table, $where = array(), $sort = array(), $limit = '', $skip = '') { n5 R) c3 t% a
- if (!empty($where)) {9 I, i5 K! @/ v: e& d
- $data = $this->database->$table->find($where);( C4 m0 I! w0 h( E
- } else {
* o( j1 h/ ?2 d2 `2 y - $data = $this->database->$table->find();
3 }5 O6 e* X/ F9 r - }. R0 x: D, W; j$ P
- if (!empty($sort)) {
. j `6 b" ?, W. ] - $data = $data->sort($sort);
" X. V' ?: c9 j7 h7 u - }
6 e! q+ B% r) x# R6 f( P' h9 c - if (!empty($limit)) {" A0 o+ h0 T9 h
- $data = $data->limit($limit);
% N: s4 [1 I r- N - }) X/ e3 O) a$ j: e& D, g' q8 {
- if (!empty($skip)) {
. n1 d7 F) [4 d9 m - $data = $data->skip($skip);
( u, n. A& e) _4 h3 w @5 t. ^$ s8 w - }3 u8 [' {; H: m+ Z8 m. }8 Z! e" j
- $newData = array();$ \* s2 J: V; K6 E! j/ R
- while ($data->hasNext()) {
& z- S% N* ^- ]) I - $newData[] = $data->getNext();; b# Y5 `5 P8 z8 Y- K
- }
. A$ \1 R3 ~3 V" _$ Q! I( N - if (count($newData) == 0) {# c) }. M" [. a/ ?; v2 B* O! W
- return 0;
- K$ }1 [' B2 C2 ^ - }& V: Z' v5 w4 y7 v) V6 G
- return $newData;
0 l _5 H( S, C - }
$ I2 V y5 P j0 v+ p, O - /**9 z m# a( R) |2 s1 m# M1 v
- * 查询指定一条数据1 W& @" a! w3 C
- * @param $table
5 v9 ]: J9 }' x: H; \/ {" p - * @param array $where3 X3 d4 s$ o9 F5 Z
- * @return int
& c2 I& L* j& R2 w- p" z+ a - */
# h- n) F: ~0 k1 Q% X5 I. G% Z - public function getOne($table, $where = array()) {' X, I; A$ d5 X3 z
- if (!empty($where)) {
6 g) f: s8 t/ w' o7 O - $data = $this->database->$table->findOne($where);
7 n! i# e$ p) N. H1 l- A- Q - } else {
; {6 L7 X. Z2 ~: s0 B! ~ - $data = $this->database->$table->findOne();
5 K/ n' m( ?( ?$ D9 P" E - }
) u0 K* k. M0 U3 o - return $data;
; w" `5 H5 g+ X8 y - }
2 Y* S4 d% K' m# ~ - /**
+ D$ R$ V: y+ o4 i4 K - * 统计个数$ ^' Q+ x0 x8 A- p2 p
- * @param $table
0 Z' F" H$ W9 L, s% [4 W - * @param array $where5 Q3 O0 q) Z, `: r" _; N4 b9 M- A
- * @return mixed
I$ v: J) @* Q: X/ f - */
) r, u3 k7 m' A$ e' ?9 z; K+ a - public function getCount($table, $where = array()) {* @2 @! v9 R9 }0 H% s, W; C" R: n6 O/ F
- if (!empty($where)) {& ]. h: l2 g. D b# J$ Q& z
- $data = $this->database->$table->find($where)->count();
3 c* X4 U; q+ y( f+ o B - } else {, ~6 u s6 ]- P8 B
- $data = $this->database->$table->find()->count();
) K- c3 u+ n* B1 P" O, b- J - }9 g3 c8 [' l$ {* e
- return $data;
' h, ]7 I3 E" P0 Q - } Z3 y3 w/ ^6 z) p8 j. e) m/ `
- /**6 |* r; w1 [: u
- * 直接执行mongo命令# ?. R# F" t! L. u
- * @param $sql
/ |. H. w7 n& a+ z# P0 v - * @return array T0 r' j6 L& I6 c
- */' Z& j* \/ X! Z6 P
- public function toExcute($sql) {8 r5 a$ U2 R4 m7 o2 h/ Z
- $result = $this->database->execute($sql);% t: V, D; K, z2 x) {6 U! x1 f6 }
- return $result;7 ?! |1 c4 t8 x' J6 ^8 z! w
- }
d/ ~) z5 q1 D, S/ b - /**/ a% P: G' |6 g* `" o0 D N8 {
- * 分组统计个数
5 c# J& ]) J( _: \8 \$ j - * @param $table
9 X* y% r6 ^) C9 _ - * @param $where
2 P0 R. y3 S# P! y - * @param $field
- l" R$ T" j: X( s - */
8 v# p4 L1 Z. \1 o9 Z/ M - public function groupCount($table, $where, $field) {$ C ~4 C8 N5 A4 F9 i! V
- $cond = array(
% J; p3 z, U+ G - array(
6 i2 S, `4 d7 q# [6 E6 j& I - '$match' => $where,
' H2 @/ v+ O& I! ]* ~9 v; ? - ),
" \: I6 w t; `7 `8 B u - array( c( _8 G( {! z* X* H
- '$group' => array(
& E$ E* I0 Q; V. M - '_id' => '
2 Y: N0 P0 b# f; ^) c" J
3 p0 ?' n& C4 u" e- . $field,
q( m& v! N, R, q% d7 O - 'count' => array('$sum' => 1),/ R6 d( J8 f2 G
- ),' p! S: L& Y. Y+ ^- K6 r
- ),7 w% j9 {; I9 P7 k* R$ K& j' p. d
- array(9 b( Z, z9 s% p+ }) J+ [9 y
- '$sort' => array("count" => -1),4 @0 }. b8 h0 V5 b5 ~ L/ v
- ),
1 V4 H) \$ S8 i9 K. H- x - );
" }" g g/ [7 j1 M - $this->database->$table->aggregate($cond); d7 T5 r% i8 X0 L" R$ Q3 a- k
- }2 ]4 ]3 H1 H3 V( \
- /**
# j/ S1 H5 |6 p) W1 A3 e) m - * 删除数据
6 F- q6 H, p0 v, A6 ^$ l/ L% o' W! [ - * @param $table. @+ j/ O7 Z# ^+ D- m6 z
- * @param $where- a: k; M3 i9 Q* v- f
- * @return array|bool. B1 K/ Y- T5 U* K- `( D, S$ a( g. q
- */
5 x* D0 L* ?- }8 P& X9 { - public function toDelete($table, $where) {) c9 C" g4 r' D: d$ d3 Y' b q: q1 G
- $re = $this->database->$table->remove($where);
$ ?: \; t$ _, D - return $re;9 z+ V! {' r8 q6 u0 u3 H
- }
0 b0 J F; X% G - /**+ S- G6 _: @8 u
- * 插入数据
& v" B6 s g7 N1 ~6 g% ~! I - * @param $table J; E# S) r2 Q4 ?1 ?7 j( c
- * @param $data
. p( y. j8 I: ^1 z' a8 H& t6 K - * @return array|bool
9 S$ T/ m d; L - */
' D: b9 g9 b. n - public function toInsert($table, $data) {5 D2 L& ]" @ B4 f) T3 G# j
- $re = $this->database->$table->insert($data);
, K5 J1 M$ }0 a1 L9 l. J2 v0 Z' h - return $re;
/ h U! Z7 {4 g1 D - }
6 t1 v' L/ R' C. d/ V - /**% G6 d; M6 M. a
- * 更新数据
% k! j: k: r6 _6 ~9 t - * @param $table* {9 N! K3 c8 ^7 ^# e8 f) X) B
- * @param $where/ y$ S* m. J7 Q8 N9 m3 N
- * @param $data: ^! u0 f. l1 k. a1 j
- * @return bool7 \( Q; T9 O- K1 a
- */
: x5 A& _9 Q. `2 h - public function toUpdate($table, $where, $data) {
" M4 v; B- j2 F - $re = $this->database->$table->update($where, array('$set' => $data));5 ]: ~% W6 D% i
- return $re; [8 R; V! w( T: g7 {0 |- D
- }
. K7 @! C n8 P' G. ? - /**
: ?8 y1 f$ [0 Z0 ^1 `/ X( f - * 获取唯一数据
1 r- K3 v$ J J% C4 `0 d" p - * @param $table
- c2 \) j3 Z+ u4 }9 ?5 Q4 s7 D - * @param $key9 N4 p9 p& j7 |& j8 G
- * @return array/ D% M) t) z. X, I6 Q5 S
- */7 C! Y) L5 m0 k* x; }: k6 X& j$ I
- public function distinctData($table, $key, $query = array()) {
4 q5 [( Q' f! y$ O' u) Z9 d: Y! m - if (!empty($query)) {5 F4 D& g+ u: O
- $where = array('distinct' => $table, 'key' => $key, 'query' => $query);3 s6 X& L# H' M9 L; {' [) P9 ~
- } else {( S( ], A- w2 r. h
- $where = array('distinct' => $table, 'key' => $key);. X4 |; `# M/ s
- }
+ v7 D' n3 J% K% S& M2 w - $data = $this->database->command($where);
: t z0 Z2 b& f7 z6 T) k' V% R) u) z - return $data['values'];
/ i, r" y5 H. F9 A H8 k - }8 U" C( u7 g+ @8 d
- }
( Y/ {6 {- c f% _: d: C1 k - ?>
复制代码 , a, m% _. a* q
0 M. T$ j8 H0 H8 I" k6 ]0 M# g |