您尚未登录,请登录后浏览更多内容! 登录 | 立即注册

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 12512|回复: 0
打印 上一主题 下一主题

[php学习资料] PHP实现的mongoDB数据库操作类完整实例

[复制链接]
跳转到指定楼层
楼主
发表于 2019-3-9 02:49:05 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

本文实例讲述了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数据库的数据库操作类源码如下,仅供参考。

  1. <?php
    $ _, ?! Q8 S7 S! A4 g6 j
  2. /**9 I' Q! }8 d" I4 y" J
  3. * PHP操作mongodb数据库操作类
      V, R7 |' ~) Q5 I7 m, r1 Z+ m
  4. */
    2 J$ Q, ~+ s- A: I
  5. class Database {, j) c- B1 L8 {
  6.   protected $database  = '';
    % E6 ?. J- F" I. T' c% [
  7.   protected $mo;
    . x1 }9 S! Y2 D% |) \
  8.   /**" e, X- v+ }% \8 d' y7 }& U
  9.    * 构造方法
    % P. O" \4 C& d& U
  10.    */8 ], Q* P8 {* F/ ~5 u. u
  11.   public function __construct() {* a" U0 a: ?8 h% w! L& F
  12.     $server = DBSERVER;2 c0 v& u& F6 `, r6 E0 Y
  13.     $user = DBUSER;8 J- S, ?$ r& T
  14.     $password = DBPASS;$ w2 b- U6 T9 [! D, v
  15.     $port = DBPORT;
    6 f: J/ [" N% w  q% [4 v5 V( h
  16.     $database = DBNAME;- {+ k; \. |+ K# M% F  n
  17.     $mongo = $this->getInstance($server, $user, $password, $port);0 I3 l1 B/ m- G' b0 E7 o
  18.     $this->database = $mongo->$database;
    4 \5 F7 T7 n, z0 Z
  19.   }
    5 K2 ?! p9 ]9 O- p# H
  20.   /**
    . G3 B6 x. U! Y- [5 G  G7 N
  21.    * 数据库单例方法7 b% O+ `/ v- M1 B: Q, `' `
  22.    * @param $server. A5 P8 \: o- R& A# h
  23.    * @param $user$ I. f% J7 {) X. K. f
  24.    * @param $password4 q8 ]$ I: R  b# s9 w
  25.    * @param $port3 c" `3 q$ h9 r) |
  26.    * @return Mongo" g- ?" g* r7 }2 [; ?  X) y
  27.    */. `  b& O- f7 n$ i& z
  28.   public function getInstance($server, $user, $password, $port) {6 k3 w4 `$ h. I
  29.     if (isset($this->mo)) {
    0 V8 J% H8 ^% a8 P* ~
  30.       return $this->mo;
    7 E8 P8 m, q, L
  31.     } else {
    1 W1 Q+ g4 d8 y9 }$ N
  32.       if (!empty($server)) {3 a: E: `) A# w3 Z) J" d
  33.         if (!empty($port)) {
    / _' G) z/ y7 J  `2 P
  34.           if (!empty($user) && !empty($password)) {* {5 F5 w; ^* X7 k
  35.             $this->mo = new Mongo("mongodb://{$user}:{$password}@{$server}:{$port}");/ D+ G" S9 r+ i) d; A/ b
  36.           } else {. u4 g9 `3 q" f% ^9 w% S2 h
  37.             $this->mo = new Mongo("mongodb://{$server}:{$port}");7 ~) |  [: A" u
  38.           }8 ^% k* C" O# m* I/ l
  39.         } else {3 n/ D; w0 I" i! \" }( F
  40.           $this->mo = new Mongo("mongodb://{$server}");' ~/ V3 M6 [% C& ]
  41.         }( }' W/ S2 T! v* h: @
  42.       } else {
    / ^6 s. G+ b; J7 [
  43.         $this->mo = new Mongo();
    : {3 ^: I$ ^; D
  44.       }% ]' t  F( h! G/ d
  45.       return $this->mo;
    9 g% O! o" u9 @& N6 E% e% N7 O
  46.     }) J1 P2 J7 _* W( U
  47.   }
    + R9 w. _' x! h' ~. P1 v$ ~' W1 N( L
  48.   /**8 p' D4 F1 D% n) ?8 ]
  49.    * 查询表中所有数据3 L4 B0 f" K/ u& q
  50.    * @param $table
    8 m5 e8 W5 V7 o9 f6 ~& u! ^  o  V
  51.    * @param array $where- b+ G: W! w( A4 ]
  52.    * @param array $sort6 I) o; S* s- I3 l3 L
  53.    * @param string $limit
      z( P1 S2 r0 G# _
  54.    * @param string $skip; D% X% ]/ L5 s4 ]
  55.    * @return array|int
    0 m+ n  f( b" O$ r* l* J  x! O1 C
  56.    */
    # Z; T% j  c2 t9 J
  57.   public function getAll($table, $where = array(), $sort = array(), $limit = '', $skip = '') {  n5 R) c3 t% a
  58.     if (!empty($where)) {9 I, i5 K! @/ v: e& d
  59.       $data = $this->database->$table->find($where);( C4 m0 I! w0 h( E
  60.     } else {
    * o( j1 h/ ?2 d2 `2 y
  61.       $data = $this->database->$table->find();
    3 }5 O6 e* X/ F9 r
  62.     }. R0 x: D, W; j$ P
  63.     if (!empty($sort)) {
    . j  `6 b" ?, W. ]
  64.       $data = $data->sort($sort);
    " X. V' ?: c9 j7 h7 u
  65.     }
    6 e! q+ B% r) x# R6 f( P' h9 c
  66.     if (!empty($limit)) {" A0 o+ h0 T9 h
  67.       $data = $data->limit($limit);
    % N: s4 [1 I  r- N
  68.     }) X/ e3 O) a$ j: e& D, g' q8 {
  69.     if (!empty($skip)) {
    . n1 d7 F) [4 d9 m
  70.       $data = $data->skip($skip);
    ( u, n. A& e) _4 h3 w  @5 t. ^$ s8 w
  71.     }3 u8 [' {; H: m+ Z8 m. }8 Z! e" j
  72.     $newData = array();$ \* s2 J: V; K6 E! j/ R
  73.     while ($data->hasNext()) {
    & z- S% N* ^- ]) I
  74.       $newData[] = $data->getNext();; b# Y5 `5 P8 z8 Y- K
  75.     }
    . A$ \1 R3 ~3 V" _$ Q! I( N
  76.     if (count($newData) == 0) {# c) }. M" [. a/ ?; v2 B* O! W
  77.       return 0;
    - K$ }1 [' B2 C2 ^
  78.     }& V: Z' v5 w4 y7 v) V6 G
  79.     return $newData;
    0 l  _5 H( S, C
  80.   }
    $ I2 V  y5 P  j0 v+ p, O
  81.   /**9 z  m# a( R) |2 s1 m# M1 v
  82.    * 查询指定一条数据1 W& @" a! w3 C
  83.    * @param $table
    5 v9 ]: J9 }' x: H; \/ {" p
  84.    * @param array $where3 X3 d4 s$ o9 F5 Z
  85.    * @return int
    & c2 I& L* j& R2 w- p" z+ a
  86.    */
    # h- n) F: ~0 k1 Q% X5 I. G% Z
  87.   public function getOne($table, $where = array()) {' X, I; A$ d5 X3 z
  88.     if (!empty($where)) {
    6 g) f: s8 t/ w' o7 O
  89.       $data = $this->database->$table->findOne($where);
    7 n! i# e$ p) N. H1 l- A- Q
  90.     } else {
    ; {6 L7 X. Z2 ~: s0 B! ~
  91.       $data = $this->database->$table->findOne();
    5 K/ n' m( ?( ?$ D9 P" E
  92.     }
    ) u0 K* k. M0 U3 o
  93.     return $data;
    ; w" `5 H5 g+ X8 y
  94.   }
    2 Y* S4 d% K' m# ~
  95.   /**
    + D$ R$ V: y+ o4 i4 K
  96.    * 统计个数$ ^' Q+ x0 x8 A- p2 p
  97.    * @param $table
    0 Z' F" H$ W9 L, s% [4 W
  98.    * @param array $where5 Q3 O0 q) Z, `: r" _; N4 b9 M- A
  99.    * @return mixed
      I$ v: J) @* Q: X/ f
  100.    */
    ) r, u3 k7 m' A$ e' ?9 z; K+ a
  101.   public function getCount($table, $where = array()) {* @2 @! v9 R9 }0 H% s, W; C" R: n6 O/ F
  102.     if (!empty($where)) {& ]. h: l2 g. D  b# J$ Q& z
  103.       $data = $this->database->$table->find($where)->count();
    3 c* X4 U; q+ y( f+ o  B
  104.     } else {, ~6 u  s6 ]- P8 B
  105.       $data = $this->database->$table->find()->count();
    ) K- c3 u+ n* B1 P" O, b- J
  106.     }9 g3 c8 [' l$ {* e
  107.     return $data;
    ' h, ]7 I3 E" P0 Q
  108.   }  Z3 y3 w/ ^6 z) p8 j. e) m/ `
  109.   /**6 |* r; w1 [: u
  110.    * 直接执行mongo命令# ?. R# F" t! L. u
  111.    * @param $sql
    / |. H. w7 n& a+ z# P0 v
  112.    * @return array  T0 r' j6 L& I6 c
  113.    */' Z& j* \/ X! Z6 P
  114.   public function toExcute($sql) {8 r5 a$ U2 R4 m7 o2 h/ Z
  115.     $result = $this->database->execute($sql);% t: V, D; K, z2 x) {6 U! x1 f6 }
  116.     return $result;7 ?! |1 c4 t8 x' J6 ^8 z! w
  117.   }
      d/ ~) z5 q1 D, S/ b
  118.   /**/ a% P: G' |6 g* `" o0 D  N8 {
  119.    * 分组统计个数
    5 c# J& ]) J( _: \8 \$ j
  120.    * @param $table
    9 X* y% r6 ^) C9 _
  121.    * @param $where
    2 P0 R. y3 S# P! y
  122.    * @param $field
    - l" R$ T" j: X( s
  123.    */
    8 v# p4 L1 Z. \1 o9 Z/ M
  124.   public function groupCount($table, $where, $field) {$ C  ~4 C8 N5 A4 F9 i! V
  125.     $cond = array(
    % J; p3 z, U+ G
  126.       array(
    6 i2 S, `4 d7 q# [6 E6 j& I
  127.         '$match' => $where,
    ' H2 @/ v+ O& I! ]* ~9 v; ?
  128.       ),
    " \: I6 w  t; `7 `8 B  u
  129.       array(  c( _8 G( {! z* X* H
  130.         '$group' => array(
    & E$ E* I0 Q; V. M
  131.           '_id' => '
    2 Y: N0 P0 b# f; ^) c" J

  132. 3 p0 ?' n& C4 u" e
  133. . $field,
      q( m& v! N, R, q% d7 O
  134.           'count' => array('$sum' => 1),/ R6 d( J8 f2 G
  135.         ),' p! S: L& Y. Y+ ^- K6 r
  136.       ),7 w% j9 {; I9 P7 k* R$ K& j' p. d
  137.       array(9 b( Z, z9 s% p+ }) J+ [9 y
  138.         '$sort' => array("count" => -1),4 @0 }. b8 h0 V5 b5 ~  L/ v
  139.       ),
    1 V4 H) \$ S8 i9 K. H- x
  140.     );
    " }" g  g/ [7 j1 M
  141.     $this->database->$table->aggregate($cond);  d7 T5 r% i8 X0 L" R$ Q3 a- k
  142.   }2 ]4 ]3 H1 H3 V( \
  143.   /**
    # j/ S1 H5 |6 p) W1 A3 e) m
  144.    * 删除数据
    6 F- q6 H, p0 v, A6 ^$ l/ L% o' W! [
  145.    * @param $table. @+ j/ O7 Z# ^+ D- m6 z
  146.    * @param $where- a: k; M3 i9 Q* v- f
  147.    * @return array|bool. B1 K/ Y- T5 U* K- `( D, S$ a( g. q
  148.    */
    5 x* D0 L* ?- }8 P& X9 {
  149.   public function toDelete($table, $where) {) c9 C" g4 r' D: d$ d3 Y' b  q: q1 G
  150.     $re = $this->database->$table->remove($where);
    $ ?: \; t$ _, D
  151.     return $re;9 z+ V! {' r8 q6 u0 u3 H
  152.   }
    0 b0 J  F; X% G
  153.   /**+ S- G6 _: @8 u
  154.    * 插入数据
    & v" B6 s  g7 N1 ~6 g% ~! I
  155.    * @param $table  J; E# S) r2 Q4 ?1 ?7 j( c
  156.    * @param $data
    . p( y. j8 I: ^1 z' a8 H& t6 K
  157.    * @return array|bool
    9 S$ T/ m  d; L
  158.    */
    ' D: b9 g9 b. n
  159.   public function toInsert($table, $data) {5 D2 L& ]" @  B4 f) T3 G# j
  160.     $re = $this->database->$table->insert($data);
    , K5 J1 M$ }0 a1 L9 l. J2 v0 Z' h
  161.     return $re;
    / h  U! Z7 {4 g1 D
  162.   }
    6 t1 v' L/ R' C. d/ V
  163.   /**% G6 d; M6 M. a
  164.    * 更新数据
    % k! j: k: r6 _6 ~9 t
  165.    * @param $table* {9 N! K3 c8 ^7 ^# e8 f) X) B
  166.    * @param $where/ y$ S* m. J7 Q8 N9 m3 N
  167.    * @param $data: ^! u0 f. l1 k. a1 j
  168.    * @return bool7 \( Q; T9 O- K1 a
  169.    */
    : x5 A& _9 Q. `2 h
  170.   public function toUpdate($table, $where, $data) {
    " M4 v; B- j2 F
  171.     $re = $this->database->$table->update($where, array('$set' => $data));5 ]: ~% W6 D% i
  172.     return $re;  [8 R; V! w( T: g7 {0 |- D
  173.   }
    . K7 @! C  n8 P' G. ?
  174.   /**
    : ?8 y1 f$ [0 Z0 ^1 `/ X( f
  175.    * 获取唯一数据
    1 r- K3 v$ J  J% C4 `0 d" p
  176.    * @param $table
    - c2 \) j3 Z+ u4 }9 ?5 Q4 s7 D
  177.    * @param $key9 N4 p9 p& j7 |& j8 G
  178.    * @return array/ D% M) t) z. X, I6 Q5 S
  179.    */7 C! Y) L5 m0 k* x; }: k6 X& j$ I
  180.   public function distinctData($table, $key, $query = array()) {
    4 q5 [( Q' f! y$ O' u) Z9 d: Y! m
  181.     if (!empty($query)) {5 F4 D& g+ u: O
  182.       $where = array('distinct' => $table, 'key' => $key, 'query' => $query);3 s6 X& L# H' M9 L; {' [) P9 ~
  183.     } else {( S( ], A- w2 r. h
  184.       $where = array('distinct' => $table, 'key' => $key);. X4 |; `# M/ s
  185.     }
    + v7 D' n3 J% K% S& M2 w
  186.     $data = $this->database->command($where);
    : t  z0 Z2 b& f7 z6 T) k' V% R) u) z
  187.     return $data['values'];
    / i, r" y5 H. F9 A  H8 k
  188.   }8 U" C( u7 g+ @8 d
  189. }
    ( Y/ {6 {- c  f% _: d: C1 k
  190. ?>
复制代码
, a, m% _. a* q

0 M. T$ j8 H0 H8 I" k6 ]0 M# g
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 18:39 , Processed in 0.107847 second(s), 22 queries .

Copyright © 2001-2024 Powered by cncml! X3.2. Theme By cncml!