cncml手绘网

标题: 使用PHP操作MongoDB [打印本页]

作者: admin    时间: 2019-3-9 02:13
标题: 使用PHP操作MongoDB
链接数据库
! {  a( O  R2 m$ d! G  `- ^; v" Y& b使用下面的代码创建一个数据库链接
# x8 L" d* x4 t3 z. F
  1. <?php# @. w/ {" z* n7 e! Z
  2. $connection = new Mongo(mongodb://192.168.1.5:27017); //链接到 192.168.1.5:27017//27017端口是默认的。
    0 f8 ~0 J' M; `# d
  3. $connection = new Mongo( "example.com" ); //链接到远程主机(默认端口)
    ! a' u! X1 h2 ~4 R% F
  4. $connection = new Mongo( "example.com:65432" ); //链接到远程主机的自定义的端口
    + f7 _/ h6 T! Y0 M: c! [
  5. print_r($connection->listDBs());//能打印出数据库数组,看看有几个数据库。
复制代码
: m! }" F( Z' R  Q- ~
上图说有一个数据库名字叫local,总大小1个字节,他是空的。看见ok表示运行成功。
/ w0 D. o5 ~0 e8 z
% d/ x; ]0 i% |* P& Y, i
?>9 E8 d( T) @! B+ w) U; r

: F" p. K7 j8 v1 ?% Q6 D: U% q

0 l- {( F9 w( j. Z
现在你可以使用$connection链接来操作数据库了
选择数据库/ X2 a- t# n% Q
使用下面的代码来选择一个数据库

# B4 p" ~- N7 G- u
  1. <?php
    1 L5 Y: T. g/ l0 w  t0 r
  2. $db = $connection->dbname;
    7 w1 f$ S& h# i& \5 ?: t; A" h' G
  3. ?>
复制代码
这里的数据库并不一定是一个已经存在的数据库,如果所选择的数据库不存在,则会新建一个数据库,所以在选择数据库的时候,注意一定要填上正确的数据库名
# ?+ a' q: q( `4 u如果拼写错误的话,很有可能会新建一个数据库
  1. <?php
    - t3 t; o, q3 S2 |
  2. $db = $connection->mybiglongdbname;) D6 g9 C& u+ e) b  d: O
  3. //做一些事情& Y* z. i# [0 Q1 ~5 W" E& v
  4. $db = $connection->mybiglongdbnme;" `0 t1 P- ]9 \5 q. r9 i2 H7 [
  5. //现在会连上一个新的数据库$ c7 D( r* W, S0 l8 N
  6. ?>
复制代码
获取一个集合' S1 i0 w+ J0 i
获取一个集合跟选择数据库拥有相同的语法格式
- l/ ?. i7 o9 }! k1 u* ]" B9 ]
  1. <?php1 _* [8 R9 T4 s- z
  2. $db = $connection->baz;//选择数据库$ {. Y: g; T& P& |/ I* G
  3. $collection = $db->foobar;//选择foobar集合) I6 G# x" V8 r6 }5 ?
  4. //或者使用更简洁的方式7 `2 K4 m1 k* N0 l( |/ M
  5. $collection = $connection->baz->foobar;
    1 ?6 e3 ]$ ]- M; p
  6. ?>
复制代码

' h6 X& G( J1 b2 Y( `  ~! `; @6 |  d: N0 l5 A7 M2 [+ Q" B" P
插入一个文档
0 g' j, g: C6 |' N& u多维数组是可以被储存到数据库中的基本单元+ }5 E8 m: Y' o/ Q+ r4 G( t
一个随机的文档可能是这样
$ s8 m( G  j5 H
  1. <?php
    $ r3 ^- e. i  B% Q7 i: q
  2. $doc = array(" O! ?- D/ S/ z
  3. ”name” => “MongoDB”,
    & W" W4 @. Z  ?8 l5 K9 }! D; F
  4.     “type” => “database”,3 V0 m  U6 B: t8 J+ [% h' a
  5.     “count” => 1,+ u8 n+ y9 U$ O+ w0 _
  6.     “info” => (object)array( “x” => 203,
    ' _4 W& W( H1 O8 k4 K- @2 W
  7.     “y” => 102),
    ( y$ X2 Q0 f# S
  8.     “versions” => array(“0.9.7″, “0.9.8″, “0.9.9″). ]& M; J" @* I$ c' u6 \; O
  9. );( }  d2 _6 J8 l# Z! Y
  10. ?>
复制代码
注意:你可以嵌套数组与对象,对象与文档在mongodb中几乎是一样的,你可以使用$doc调用一个文档或对象,但是info字段总是一个对象而不是一个文档," U) N& h' j  ?
本约束适用于所有文档
使用MongoCollection::insert()插入一个文档

( @. p5 A# _: y7 F
  1. <?php
    & c& \3 \) i8 d4 z5 g
  2. $m = new Mongo();& t: I$ O) N; u! H: n
  3. $collection = $m->foo->bar;2 x) Z3 V; L# [) U
  4. $collection->insert($doc);; t* ~( J, k$ J1 {) t
  5. ?>
复制代码

) V$ ~' x3 d! v( hmongodb 的 insert()、save()  ,区别主要是:若存在主键,insert()  不做操作,而save() 则更改原来的内容为新内容。
存在数据:  { _id : 1, " name " : " n1 " }
insert({ _id : 1, " name " : " n2 " })    会提示错误
save({ _id : 1, " name " : " n2 " })     会把 n1 改为  n2  。
使用MongoCollection::findOne()查询文档
! Z8 c, {* ~5 _# e, _为了证明上面那段代码的数据已经插入到数据库里了,我们进行简单的 findOne()操作以得到集合中的第一个文档数据,这种方法只返回一个文档数据,* G; _) |' J. K3 \
这种方法适用于在你的查询语句的时候只匹配一个文档或者你只关心第一条数据
8 ^) H0 f1 d) N5 s% {: D1 S' O
  1. <?php
    ( ~7 C' Q7 t3 v0 J8 W, K6 J
  2. $obj = $collection->findOne();$ v1 U2 m9 N& N/ R. R
  3. var_dump( $obj );* @8 l* n4 c- @, j# I- h
  4. ?>
    " j. d- Y9 B3 K. E) e
  5. 你会看到下列结果3 @2 U- _  V) z/ w
  6. array(5) {
    5 s# ~; `7 \5 D1 A
  7.   ["_id"]=>
    , Y- q" ^: i/ F0 J
  8.   object(MongoId)#6 (0) {
    9 a- o. U5 I6 ?' H" s
  9.   }
    . R4 i. c* B( Q- j# _% L
  10.   ["name"]# v' `% P4 P; M( D" |  k& Z! f
  11.   string(7) “MongoDB”1 e% ]1 i* U& z
  12.   ["type"]=># V9 C: V" e( K: `3 v1 _
  13.   string(8) “database”7 i: C! j. D/ k. V
  14.   ["count"]=>
    1 {1 m0 a$ A, ]* J& n
  15.   int(1)
    7 h+ B4 i# Q7 O/ ]9 n3 Y: ^3 z4 U# d
  16.   ["info"]=>
    5 q. S. }  S2 I3 ^# }
  17.   array (2) {3 q  X- f$ @+ J. [2 |' H
  18.     ["x"]=>. G: t# O0 R- _
  19.     int(203)" x$ h7 U% M" Z0 y. x  {& e& U
  20.     ["y"]=>
    9 d5 i/ M% e* ]1 G
  21.     int(102)( b. p, G1 l4 R7 _- {7 W2 Y/ y
  22.   }
    6 p& A- u9 ~. @
  23.   ["versions"]6 b& V4 v% L5 @" X" f/ u5 H
  24.   array(3) {
    3 t% q* |4 A& J! ]
  25.     [0]=>% _7 B9 U& i: b) W! @. A4 s! N
  26.     string(5) “0.9.7″
    ' X& s  w! Z' u
  27.     [1]=>
    , v. H) s& Z9 ~7 X
  28.     string(5) “0.9.8″# q8 q3 f: f" x7 \  z. n2 m# f* r
  29.     [2]=>9 d7 u: B4 e$ J! o
  30.     string(5) “0.9.9″
    1 Y" e' I  D! B9 c. \, l5 {
  31.   }
    * m$ w9 h4 G- L4 S; j) e
  32. }
复制代码

; Z+ i* F* i/ U7 g, {( l" Q! G- L7 Y- y
注意_id字段自动加载了文档上,MongoDB储存元素中以_以及$开头的都是供内部使用的
添加更多文档1 ]$ A7 |5 U3 m) ~8 }, Z/ T0 r0 R
为了做一些更有趣的事情,我们添加更多简单的文档到集合中,这些文档如下

; v: |% F0 s9 }
  1. <?php' n  s* T; h: S9 E( U
  2. array( “i” => value );8 v; d& D7 T3 l
  3. ?>
复制代码
我们可以使用循环相当有效的插入数据; d  J* _8 e+ r
  1. <?php$ Z! X* q" @8 n% K& Y. h* n3 D4 S
  2. for($i=0; $i<100; $i++) {
    5 k' i8 g' e$ s, e- ]
  3.     $collection->insert( array( “i” => $i ) );
    * s( e8 W8 c. s: v
  4. }% V1 V! e6 K5 V6 I
  5. ?>
复制代码
注意:我们可以插入不同的字段在同一字符集中,在这方面意味着MongoDB拥有非常自由的储存模式
在一个集合中计算文档的数量
/ V. x/ l5 e. J: ~( N( S0 U) m现在我们插入了101个文档(我们用循环插入了100个,之前还插入了一个),我们可以使用count()来看看我们的数据是不是都被插入进去了
8 T. K$ k8 B. {% Q4 w2 J
  1. <?php
    ( L! @5 {" e6 F; h% e4 \
  2. echo $collection->count();5 }+ Y% n( D! I5 P4 J' J
  3. ?>
复制代码
这段代码将打印出101% m$ E  Y6 V+ t; c+ X3 O6 ~, U
MongoCollection::count() 也可以查询字段数据
使用游标得到集合中的所有文档
/ K& O; C% _/ i1 F( N# D为了得到集合中的所有文档,我们可以使用 MongoCollection::find()方法,find()方法返回一个 MongoCursor对象,可以让我们重复得到查询, Q# K: Z( y( j6 N- m" N4 `) M
所匹配的的文档
  1. <?php/ O+ s, G7 N! o4 |# K/ d
  2. $cursor = $collection->find();/ q7 y9 b- t  i* a4 I
  3. foreach ($cursor as $id => $value) {2 {1 y: j( x4 z. P; y+ N
  4.     echo “$id: “;  i5 \7 m5 t4 v) G& }
  5.     var_dump( $value );
    + X" h% L' s6 {) K6 Y
  6. }! A0 y6 X' w' z% L" f, f
  7. ?>
复制代码
这样我们会打印出集合中的这101个文档,$id就是文档中的_id字段,$value 就是文档本身
为查询规定一个标准) q, e/ v0 o! }5 I4 N2 J
我们可以通过find()方法得到集合中的文档子集,例如,我们要查询出集合中i字段为71的文档,我们可以使用下列方法

) ?% {1 B) [  l7 W+ v. U( l, X3 k
  1. <?php2 c- V1 ?2 C1 ^* `( L
  2. $query = array( “i” => 71 );; n  W, {+ O" C! ~
  3. $cursor = $collection->find( $query );& W8 f8 y8 v2 ~$ N
  4. while( $cursor->hasNext() ) {  Y# O! E, w3 u+ h+ G
  5.     var_dump( $cursor->getNext() );5 R# T( ]  J  C
  6. }
    3 i  Y, K1 d: N% a9 P3 H! x
  7. ?>
复制代码
我们将打印如下数据/ S1 s+ P7 b: c
  1. array(2) {
    ( ?0 l  `2 r/ p# g
  2.   ["_id"]=>4 b; T7 H( w2 [' F2 f7 k2 a; ^
  3.   object(MongoId)#6 (0) {5 O, v6 k/ n* ]- r+ y5 ^. Z
  4.   }- m5 e4 P3 W, l! H/ t
  5.   ["i"]=>
    8 X$ G4 q! c) D3 Z
  6.   int(71)
    ) q: I* G! o( p# n  t3 [+ {
  7.   ["_ns"]=>! C1 m6 e. K0 q- o* [9 I
  8.   “testCollection”" m# ^! \' Y( q6 i- w( b1 T
  9. }
复制代码
为查询设定一个范围
  c) v. @# b9 @& V我们可以通过find()创建一个查询语句以得集合中的一个子集,例如如果我们得到所有”i”>50的文档,我们可以使用如下代码2 ?6 F) E- z. p3 L( t
  1. <?php
    $ Z  O3 X, ~6 A- u4 f
  2. $query = array( “i” => array(‘$gt’ =>50)); //注意’$gt’两边的单引号
    . v. z% s8 m/ ~  A
  3. $cursor = $coll->find( $query );( O' N6 Z: g' J' U. l  N" L  K
  4. while( $cursor->hasNext() ) {
    2 g$ O; k+ T! P# R
  5.     var_dump( $cursor->getNext() );
    / l& B6 h  q6 [1 J' @
  6. }
    1 P9 c7 M' a# K- X" h$ P/ K, C
  7. ?>
复制代码
我们同样可以得到20 < i <= 30之间的数据  K7 t/ ^% X# Z
  1. <?php
    1 |. }2 C% X5 U; Y( e& O& R
  2. $query = array( “i” => array( “\$gt” => 20, “\$lte” => 30 ) );
    6 ]8 `2 W- Z) J$ ]# G: L. |) }* I
  3. $cursor = $coll->find( $query );; Z+ q& R& D7 T# M2 X- h( z) \1 m
  4. while( $cursor->hasNext() ) {1 g9 u7 E' x" P- Q& U
  5.     var_dump( $cursor->getNext() );
    ( k* V& y* X" o& i- u+ A
  6. }
    # E& \# H  k3 b1 r: ~% q+ }
  7. ?>
复制代码

6 O7 T% H$ e) y8 r
我们非常容易漏掉$美元符号,你也可以选择你自定义的符号来代替美元符号,选择一个不会在你的建里面出现的符号例如”:”,在php.ini中加上这么一句话
! a/ L! @" e5 u. P* l: W3 L  xmongo.cmd = “:”
4 u- l  S/ T# ~* y; z8 A那么上面的代码就可以替换成
* ]! R# J: X, H) O6 V
  1. <?php4 W7 X6 Q8 C; }& t
  2. $query = array( “i” => array( “:gt” => 20, “:lte” => 30 ) );
    % ?* D8 m! x+ F( y, a( R0 l/ q; E
  3. ?>
复制代码
9 h5 U0 P; d4 b. K3 L8 C' Y) x
当然你也可以使用ini_set(“mongo.cmd”, “:”)的方法来改变
创建一个索引
' G  u$ i3 ^- A1 ~MongoDB支持索引,并且可以很容易的加到一个集合中,你只要指定某个字段为索引就行了,并且还可以指定 正序索引(1)与 倒序索引(-1)9 t9 \# f$ |1 f( ]# f
下面的代码为I创建了索引
) u! T2 Z, w* ?3 s2 B0 c
  1. <?php
    * ?; {0 `7 W' s% F1 H* Z' [- h
  2. $coll->ensureIndex( array( “i” => 1 ) );  //在”i”上创建了一个索引  S( Q9 Y) |6 b7 J4 e! @
  3. $coll->ensureIndex( array( “i” => -1, “j” => 1 ) );//在”i”上创建了倒序索引 在”j”上创建了正序索引
      w7 F/ c& \  c- J, p0 k! A8 n' B
  4. ?>
复制代码

" b' I; \3 |! T2 U2 c  K" w
一个简单的列子* _) b. Q/ r0 N7 W3 b
这个例子展示了如何链接mongodb数据库,如何选择数据库,如何插入数据,如何查询数据,以及关闭数据库链接
  1. <?php' z+ s5 H. q- [, D9 Q
  2. //链接* |- c2 R9 t1 n/ X
  3. $m = new Mongo();, r/ I3 P1 q3 Z
  4. 4 y/ H& p6 D% K) O1 K
  5. // 选择一个数据库0 O2 s8 g" \* l5 e$ p5 }7 H& [
  6. $db = $m->comedy;' ~; J: G9 K& ?
  7. $collection = $db->cartoons;
    & ~: y0 ]& U  t0 d5 V9 C
  8. & C/ R/ }) {8 e# }7 [- Y. o
  9. //添加一个元素+ J! h+ {' `; @
  10. $obj = array( "title" => "Calvin and Hobbes", "author" => "Bill Watterson" );
    . C  w( S5 Y, ~1 O* ]0 K" N* ^
  11. $collection->insert($obj);
    ; G( a0 z; P6 S
  12. . `6 e* i. e0 H2 K6 A
  13. //添加另一个元素,使用不同的格式
    7 x  \& _! R2 m
  14. $obj = array( "title" => "XKCD", "online" => true );% `9 O% ]; D( B
  15. $collection->insert($obj);. E9 x! n& D" x7 u; Q! K4 U; k! p
  16. $ c+ L5 n# h9 D4 r
  17. //查询所有的集合4 ?1 u  b  C5 m" A: J$ t( J
  18. $cursor = $collection->find();* ]; T  @4 S* J
  19. + {+ X, b( i2 {) `0 _4 L9 y
  20. //重复显示结果: @8 ]1 V0 l; O9 Y, D/ e$ i3 ^6 \7 H
  21. foreach ($cursor as $obj) {+ S! T$ [& ~2 w
  22.     echo $obj["title"] . "\n";2 L  X3 p$ c- w3 H. H0 v" z) Q
  23. }
    1 o( n0 Z7 O6 q) r& [
  24. # ~0 v7 g7 w" P  w" y) K
  25. // 关闭链接* ], H. u/ E9 h1 ]/ x0 ~% ]. ~9 `7 ]
  26. $m->close();( T) h! u  f  p: k$ ?
  27. ?>
复制代码
2 b. [9 `: O! }5 ^+ D! b
输出结果为
! B, V2 T3 J( g; J  `
  1. Calvin and Hobbes
    : b( r4 l8 l- `3 P% {; o
  2. XKCD
复制代码
- Y5 N' r) f- s, ?
9 |1 H2 M7 [9 g$ A0 M3 I6 m% t: a

! Q1 Z- j1 Q$ A3 @
1 H& n# i$ a! L& A4 a9 \, t8 G9 x5 ^: X* o" {* U  x' @; j
  k) B! g" r9 L1 E, ]7 v4 s( ?6 \3 h
: s+ b, w1 l) B% V* |* w
* F8 @' h) ^4 S





欢迎光临 cncml手绘网 (http://www.cncml.com/) Powered by Discuz! X3.2