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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

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

[php学习资料] PHP操作MongoDB(增删改查)php7.0以下

[复制链接]
跳转到指定楼层
楼主
发表于 2019-3-5 13:50:34 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
  MongoDB的PHP驱动提供了一些核心类来操作MongoDB,总的来说MongoDB命令行中有的功能,它都可以实现,而且参数的格式基本相似。PHP7以前的版本和PHP7之后的版本对MongoDB的操作有所不同,本文主要以PHP7以前版本为例讲解PHP对MongoDB的各种操作,最后再简单说明一下PHP7以后版本对MongoDB的操作。
一、数据插入
  1. //insert(); W! A% d, K! C$ w
  2. //参数1:一个数组或对象  {. H' [! i- E# Z) ^  W
  3. //参数2:扩展选项
    0 h3 z" o  w. }1 ]' Q9 L
  4. //  fsync:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入硬盘: C# H+ d5 B6 Z( E  W( G
  5. //  j:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入日志% W' v; Z* B7 a
  6. //  w:默认为1,写操作会被(主)服务器确认,若为0则将不会得到确认,使用复制集时设置为n用于确保主服务器将数据修改成功复制到n个节点后再确认
    ) Z3 K& {8 z& Z* C- c
  7. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间! l9 W/ B+ |1 r! U: {
  8. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)/ F/ p8 K% n  ^: F" o7 A8 `
  9. $mongo = new MongoClient('mongodb://localhost:27017');
    * m3 q1 G7 {- d3 h4 y
  10. $db = $mongo->mf;//选择数据库
    1 e* `8 u6 ~7 Z/ f
  11. $collection = $db->friend;//选择文档集合0 M; ~( H/ Y9 `0 i+ p5 X# z1 _* A6 R
  12. $doc = [//定义一个文档,即一个数组
    " b" e5 z" m& k. |0 m8 z  _& |
  13.     'First Name' => 'Jet',5 \: y6 |) w+ O% h
  14.     'Last Name' => 'Wu',/ H6 k/ e, H4 A' n, c) G8 x
  15.     'Age' => 26,. w& v1 H: h, z8 N; o
  16.     'Phone' => '110',
    ' y" r3 T$ P$ @) u0 |8 ?* x8 w9 q( ^
  17.     'Address' => [
    " o  f2 t2 ~( A; m" {
  18.         'Country' => 'China',1 T/ M# e3 @+ w5 Y7 h. Y) [2 H
  19.         'City' => 'Shen Zhen'
      c  p; N- w9 ~- {* b# E( p
  20.     ],
    / a0 h) }% P$ V. }! C/ t, H
  21.     'E-Mail' => [* k) f, ]1 q  H5 H( i
  22.         '123456@qq.com'," r3 a; P: b( U0 S( A$ V2 v
  23.         '666666@sina.com',
    9 E1 z* T' ^1 n' b" ^" {2 R
  24.         '8888888@qq.com',! H# E" I& f* H; ?  ~6 l  x
  25.         '77887788@qq.com'4 P- p% B  L7 W6 x
  26.     ]- B( \5 v% w1 k9 H1 I
  27. ];1 p" `; }) H3 L. f7 }
  28. $res = $collection->insert($doc);//向集合中插入一个文档- R6 g8 f5 |1 \$ P. d0 I
  29. echo '<pre>';% i/ R. n0 M4 @6 D4 v  B+ H7 |5 T# I
  30. print_r($res);//$res['ok']=1表示插入成功
复制代码
二、数据查询
1. 查询单个文档:
  1. //findOne()/ n  L( Q6 ^) [$ p0 J1 t, S
  2. //参数1:搜索条件
    $ g$ [# A. B2 a  F+ [7 ?( q; \/ o
  3. //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非在第二个参数显式加入'_id'=>false。不设置则返回所有字段
      u/ W  T" u/ v
  4. $mongo = new MongoClient('mongodb://localhost:27017');
    ( H0 p% c) z  o. @' e/ ?- Z8 ]
  5. $db = $mongo->mf;6 q* D/ G$ D9 W. \; g
  6. $collection = $db->friend;2 k) j! {, x' @, Z: g
  7. $one = $collection->findOne(['First Name' => 'Jet']);
    ! E7 }7 K* v: I, O
  8. echo '<pre>';( Y# [! r; k3 h/ f/ y% W
  9. print_r($one);//返回一个数组,查不到数据则返回NULL
复制代码
2. 查询多个文档:
  1. //find()
    ' Z7 E9 ]( p# O) b
  2. //参数1:搜索条件, W* L+ a+ j) b( N. X3 o9 h/ O
  3. //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非显式设置为false不返回。不设置则返回所有字段
    3 r3 e9 U) \& \: h
  4. $mongo = new MongoClient('mongodb://localhost:27017');
    $ f! b" [# B  f; \$ L* x3 `
  5. $db = $mongo->mf;% L, O; {7 ~5 X6 j' n6 D+ C( V
  6. $collection = $db->friend;' {. |" e( R0 m0 c3 k$ ]) w; P1 x
  7. $cursor = $collection->find(['Address.Country' => 'China']);//使用点操作符查找数组元素" f! G' U1 `9 n/ }* s& E  v* Z
  8. echo '<pre>';: K2 f7 H1 l* j9 e! p" }, \% b3 u) G
  9. while($doc = $cursor->getNext()) {//循环读取每个匹配的文档
    ) W8 J8 k# R  T4 @- j0 s/ ^
  10.     print_r($doc);
    * a& h: r( f- n' w' S5 H& P) H
  11. }
复制代码
使用各种条件操作符定义查询:
  1. //mongodb分别使用$lt(小于)、$lte(下雨等于)、$eq(等于)、$gte(大于等于)、$gt(大于)、$ne(不等于)表示<、<=、=、>=、>、<>,用于整数字段查询+ o- D. h7 N9 s' c9 q0 h! b- g
  2. $mongo = new MongoClient('mongodb://localhost:27017');0 R+ ~4 Q+ u0 H
  3. $db = $mongo->mf;" Q3 t4 v/ X5 L* }
  4. $collection = $db->friend;
    3 e6 W) l+ B5 ?$ B% l3 G
  5. $cursor = $collection->find(['Age' => ['$gt' => 30]]);
    7 ^; d$ w3 y0 L' y
  6. echo '<pre>';" s% j0 s$ P+ X/ X  a% }
  7. while($doc = $cursor->getNext()) {3 Y- W" n' O2 z: l9 C0 T
  8.     print_r($doc);
    + {9 v* z- p6 j/ \0 g3 j& p2 G7 y
  9. }
复制代码
  //查询某个字段的所有不重复的值
2 n3 V: F# ?3 L' _  $res = $collection->distinct('Age');
  1. //$in:匹配多个值中任意一个
    7 v+ C' @* B- n6 p
  2. $cursor = $collection->find(['Address.Country' => ['$in' => ['China', 'USA']]]);9 f# O5 l. \5 H4 U& n" _

  3. 4 n+ t9 i: K% x* R) }
  4. //$all:匹配多个值中所有值(用于数组字段查询)
      a2 t# Y! K5 \- B0 I2 D1 y% g5 A( U
  5. $cursor = $collection->find(['E-Mail' => ['$all' => ['123456@qq.com', '77887788@qq.com']]]);
    7 N+ n+ E: S( Z3 w9 J

  6.   e7 t7 e. B0 _4 `$ {
  7. //$or:或查询4 k8 n  @; s; F- @1 S5 i/ j& I9 X8 P
  8. $cursor = $collection->find(['$or' => [['First Name' => 'Jet'], ['Address.Country' => 'USA']]]);
      H6 u( }+ A5 n

  9. 0 }/ X5 E- B8 U5 R  I( M  r
  10. //$slice:获取数组字段中指定数目的元素,位于find()函数第二个参数中( y# r9 @% |2 z
  11. $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => 2]]);//只返回前两个email
    , w4 Y* z) }% [% E: g+ D0 ?$ d
  12. $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => -2]]);//只返回最后两个email* ]4 s: H# p3 c- W
  13. $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => [1, 2]]]);//忽略第一个,返回接下来两个/ A. ^$ S& `: Z7 i- ?  L
  14. 9 h8 m7 _4 S. c
  15. //$exists:根据某个字段是否有设置值进行查询
    8 A% X0 Z+ {$ y3 \/ d
  16. $cursor = $collection->find(['Hobby' => ['$exists' => false]]);//查找Hobby字段未设置值的文档
    5 s+ B5 x  d/ [& p  e5 Z0 p/ g
  17. , L) R" Y- Q, t1 W
  18. //正则表达式查询
    7 [$ [; I  B" _: N
  19. $cursor = $collection->find(['First Name' => new MongoRegex('/^Je/i')]);//查找First Name字段以Je开头的文档,忽略大小写差异
复制代码
使用MongoCursor类提供的其他函数:
  1. //排序:1升序,-1降序4 p- _# Y# V* }/ d5 `/ c
  2. $cursor->sort(['Age' => 1]);7 q+ o& {' |  z# }% [. ~9 `
  3. ) V% L0 {5 u: W8 ]
  4. //忽略前n个匹配的文档. n' A( l; l' n9 L
  5. $cursor->skip(1);1 b" s2 V! e& a4 T: }0 I  u8 i

  6. 6 X8 k0 x+ z. W5 k. T+ ?7 v- I
  7. //只返回前n个匹配的文档(limit()与skip()结合使用可实现数据分页功能)3 W# O" W2 X2 ]6 p* \4 u
  8. $cursor->limit(1);
    2 q( `5 B! x  j% i* i; n

  9. 7 _% F* F9 g3 g0 k& R
  10. //匹配文档的总数4 z! |! A  h  X% Q* R) B
  11. $cursor->count();8 U1 W0 ^3 g- Q# R. l
  12. 9 u: |& D/ Q( t3 a% X8 A( x
  13. //指定查询索引! J( o3 `( P3 R
  14. $cursor->hint(['Last Name' => -1]);//若索引不存在则会报错
复制代码
聚集查询:对数据进行分组统计
  1. //聚合查询:对数据进行分组统计
    ; @" K5 |; M* z7 }  p- C: R6 S
  2. $mongo = new MongoClient('mongodb://localhost:27017');  o" o# `: _$ f, }5 ~: C
  3. $db = $mongo->mf;
    - H$ X) N) {& R3 U
  4. $collection = $db->friend;
    & {3 ^( c: P0 }2 L0 t" K
  5. $res = $collection->aggregate([' K6 h& p& q4 H0 d, I+ S
  6.     '$group' => [
    - S& O: }9 p3 V* t) M7 J
  7.         '_id' => '$Address.Country',//分组字段,注意要加上“$”,这里是根据数组字段某个元素值进行分组
    + z/ `0 U( Z- a) Z$ H+ i
  8.         'total' => ['$sum' => 1],//求总和,表示每匹配一个文档总和就加1
    ! i6 e! L4 n! m- L9 H7 w
  9.         'maxAge' => ['$max' => '$Age'],//分组中Age字段最大值$ x  i% D% z( R( I, z+ ^& M
  10.         'minAge' => ['$min' => '$Age']//分组中Age字段最小值; W# d5 Y7 `0 Y! |: l, o
  11.     ]
    5 k$ X* i3 g1 W
  12. ]);- F) k: |3 u$ y* I6 i3 q3 n
  13. echo '<pre>';+ ~  a* k3 C2 {: C/ k
  14. print_r($res);//返回一个数组,$ret['result']为数组,存放统计结果
    , j) t0 H: B. C( {. r0 C
  15. " t- }; V5 ]# W6 k5 W9 \, b. H! B

  16. 5 L; H$ p3 l* R, K; x1 t( e
  17. //存在其它操作的聚合查询:多个操作之间执行先后顺序取决于它们位置的先后顺序; S" Y% y# S. H- w; Y, N
  18. //聚合查询中的所有操作,包括'$group'在内,都是可选的。6 j7 j. t" q8 s, s
  19. $mongo = new MongoClient('mongodb://localhost:27017');
    , r) o' a" a; h: K
  20. $db = $mongo->mf;
    . u3 [; w/ r  [2 _; _/ q' q" x
  21. $collection = $db->friend;
    ' I: V8 F$ S: N. |; V- f* p
  22. $res = $collection->aggregate([" g. [0 Z1 J5 i; d. }# G+ ~+ V
  23.     [//过滤条件:只对符合条件的原始文档进行聚合运算,若是放在'$group'之后则是只返回符合条件的结果文档
    ) t3 @& X# L" z0 S
  24.         '$match' => ['Age' => ['$gt' => 30]]
    ' {' o+ D" z5 ], O2 d7 j$ i
  25.     ],
    ) X1 B- h/ d7 p/ r' ]
  26.     [//指定分组字段、统计字段
    . v2 O2 h* ]. ]+ {$ i. r) F8 z3 ^
  27.         '$group' => [
    2 Y7 F! k5 J/ x- u6 N. p; ?% Q- n- @/ G
  28.             '_id' => '$Address.Country',
    : D) g, a3 s8 v0 N- |. N; h
  29.             'totalAge' => ['$sum' => '$Age']//计算各个分组Age字段总和% h+ M( i; h8 G! \% l1 C- N  }
  30.         ]) I; _+ {. N& x/ E! T
  31.     ],
    8 I# z' W5 I5 \2 y$ x" B/ C
  32.     //以下操作若是放在'$group'之前则在聚合前作用于原始文档,若放在'$group'之后则在聚合后作用于结果文档) m+ a' K) o" p' g8 M/ J6 T* V/ _
  33.     ['$unwind' => '$E-Mail'],//将包含有某个数组类型字段的文档拆分成多个文档,每个文档的同名字段的值为数组中的一个值。
    % b6 V$ Q8 W2 G
  34.     ['$project' => ['myAge' => '$Age', 'First Name' => '$First Name']],//指定返回字段,可以对字段进行重命名,格式:返回字段名 => $原来字段名& a' p& a- m3 r( @3 r
  35.     ['$skip' => 2],//跳过指定数量的文档/ s8 W. F  F) j
  36.     ['$limit' => 2],//只返回指定数量的文档/ T' h; V: X& o# z
  37.     ['$sort' => ['totalAge' => 1]]//排序
    9 S7 F1 R7 I7 E, R# C+ f
  38. ]);5 C/ `2 |$ u: \0 o0 y8 F
  39. echo '<pre>';
    ; d) |$ r( f& w7 @; r% |
  40. print_r($res);
复制代码
+ t5 n4 s) c( i# G# Q/ j) [% ^* n9 W) p
三、数据修改
  1. //update()& [, k# w- p& a4 r3 S6 f! {% w4 i
  2. //参数1:更新条件,指定更新的目标对象。5 l2 l  ]# z/ C2 l3 i& X7 T
  3. //参数2:指定用于更新匹配记录的对象。) J% o2 o0 I$ u3 B
  4. //参数3:扩展选项组。
    " D8 M! Z% K) ~
  5. //  upsert:若设置为true,当没有匹配文档的时候会创建一个新的文档。
    1 e- B0 x5 U  J. {% Y9 V. b' q" I
  6. //  multiple:默认为false,若设置为true,匹配文档将全部被更新。! Z9 G" d/ u; t8 {
  7. //  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。- _* I; `: e% Y
  8. //  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作
    7 q( s% \" v) F1 I
  9. //  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。6 X. n& V9 a4 ?
  10. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间; r+ W& V. \) \. S. i9 Z! Q; S4 }
  11. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)" q$ k. }- l4 i- ~* `/ y
  12. //注意:若不使用任何修改操作符,则匹配文档将直接被整个替换为参数2指定的对象。: K1 n2 @# F3 E# G/ Z1 ~, S! O% T

  13. ! t) P! W! Q6 [- y% b" W
  14. //$inc:增加特定键的值,若字段不存在则新建字段并赋值
    ( Q6 W. I) S! A4 c0 e# d
  15. $mongo = new MongoClient('mongodb://localhost:27017');
    ) ^) O; ?  r& q$ a' e
  16. $db = $mongo->mf;
    / S* U/ g: n3 I4 n
  17. $collection = $db->friend;! n* u: t  g% X" \1 K
  18. $res = $collection->update(['First Name' => 'Jet'], ['$inc' => ['Age' => 2]]);
    - Z1 [& g- F! L7 t  G
  19. echo '<pre>';
    & T$ r9 @! \8 l* v, d3 e
  20. print_r($res);//$res['ok']=1表示修改成功,$res['nModified']表示修改的文档数量
    7 k. d! _! [+ E  ~' t3 _( T
  21. ' F  I4 b' w  O
  22. //$set:重置特定键的值,若字段不存在则新建字段并赋值7 \/ k/ r+ s( c# O
  23. $res = $collection->update(['First Name' => 'Jet'], ['$set' => ['Hobby' => 'pingpong']]);6 V' j& m/ I2 u/ y4 ?1 U

  24.   I& }% D/ n/ L' }( |4 B) d% |
  25. //$unset:删除字段
    : L3 N* \7 a3 ?! b# z/ C5 t
  26. $res = $collection->update(['First Name' => 'Jet'], ['$unset' => ['Hobby' => 1]]);. y5 x, }8 g/ [! }. O; x2 f. g

  27. . w0 Y  y$ l$ E4 k9 @8 k) [4 ^
  28. //$rename:重命名字段,若字段不存在则不进行任何操作! C- U' z# k9 h
  29. $res = $collection->update(['First Name' => 'Jet'], ['$rename' => ['Hobby' => 'hobby', 'Age' => 'age']]);3 i  B' d$ s$ A6 r% {
  30. //注意:如果文档中已经使用了指定名称的字段,则该字段将会被删除,然后再进行重命名操作。
    9 X7 f7 F/ U. t0 Y" x! A8 _' W1 ]  W

  31. # V1 J9 k. j; T  `( n. P
  32. //$setOnInsert:设置了upsert为true,并且发生了插入操作的时候,将某个字段设置为特定的3 k" i$ i9 l$ N! Q$ R! z$ V
  33. $res = $collection->update(['First Name' => 'jet'], ['$setOnInsert' => ['lang' => 'English']], ['upsert' => true]);
    7 G/ ]1 ~- m) H+ ^1 M
  34. : ~4 h8 E9 r8 ~
  35. //$push:向指定字段添加一个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错( y. t  ~' E! Y$ l
  36. $res = $collection->update(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '123123@qq.com']]);
      \- t, p; w# d
  37. ) O- i  t( b# i+ t
  38. //$push:向指定字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错
    $ b4 w) z+ j! a" J' q2 B
  39. $res = $collection->update(['First Name' => 'Jet'], ['$pushAll' => ['E-Mail' => ['666@qq.com', '8888888@qq.com']]]);" ]1 x+ Y5 u" v# M' }
  40. " y1 i- K( ~8 H" U+ g. a
  41. //使用$push和$each向某个字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错
    + g2 w" O6 r$ P4 h
  42. $res = $collection->update(['First Name' => 'Jet'], ['$push' => ['E-Mail' => ['$each' => ['123123@qq.com', '666@qq.com']]]]);
    ( K0 F, f- M2 K' K0 p: I7 {

  43. 7 o) W3 e7 |, w1 }1 b/ P
  44. //$addToSet:将数据添加到数组中(只在目标数组没有该数据的时候才将数据添加到数组中)2 F: H: [, B6 ^5 M1 N" p
  45. $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => '123123@qq.com']]);: k7 T8 H! r. D* f- |* P# o
  46. $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => ['$each' => ['123123@qq.com', '666@qq.com']]]]);
    0 |+ V3 J; o5 U1 K
  47. 9 c' X, F- Q' f: k
  48. //$pop:从数组中删除一个元素,-1表示删除第一个元素,1表示删除最后一个元素(其实负数都删除第一个元素,0或正数都删除最后一个元素)! F: Q( q9 ?9 q9 D
  49. $res = $collection->update(['First Name' => 'Jet'], ['$pop' => ['E-Mail' => 1]]);
    ( }. j- A% J7 [/ `( Z# z. K* y
  50. ) Y$ H+ z' W8 U6 |" ?
  51. //$pull:删除数组中所有指定值9 n- P+ v) v4 n. W' Y+ ]
  52. $res = $collection->update(['First Name' => 'Jet'], ['$pull' => ['E-Mail' => '123123@qq.com']]);5 b2 |" K, J( \
  53. , P' p3 Z: R. v, V: D
  54. //$pullAll:删除数组中多个元素的所有值1 a0 Y" u/ k- a7 ^( d
  55. $res = $collection->update(['First Name' => 'Jet'], ['$pullAll' => ['E-Mail' => ['123123@qq.com', '666@qq.com']]]);
复制代码
  1. //save()$ ^, f6 I! ?& K) V+ o; K' d/ \
  2. //参数1:希望保存的信息数组
    * y+ f; t- T7 e9 S% i( S/ h
  3. //参数2:扩展选项
    ; @: E: X, G) x0 J* p
  4. //  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。/ ^* T. N4 i% u6 \
  5. //  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作* j1 ?3 a$ w' L2 p; q
  6. //  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
    5 g% `+ @0 B$ d
  7. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间6 Z1 E0 ~) Z+ A) c' R
  8. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)! q/ H: w* q+ |0 X# b8 ^
  9. //注意:若已存在则更新,若不存在则插入;更新时使用参数1指定的信息数组替换整个文档。: V7 \2 W3 S! h; M1 q
  10. //若想更新则应该在参数1中指定_id键的值。3 C& ^( [' C5 }7 K
  11. $mongo = new MongoClient('mongodb://localhost:27017');* b3 g, j! g1 V9 x
  12. $db = $mongo->mf;
    : O* v& u) J/ X0 z0 S: o) s7 s
  13. $collection = $db->friend;
    ( D0 X6 W% u* U6 C6 r6 _
  14. $doc = [//定义一个文档,即一个数组
    7 |  E# s) M: y) k6 J8 ?' J
  15.     'First Name' => 'Jet',* N3 V/ e$ K2 T. m2 Q  A
  16.     'Last Name' => 'Wu',
    * B  S. J, [5 b
  17.     'Age' => 26,
    5 @4 c4 i; @' [/ Y6 e3 Y: z
  18.     'Phone' => '110',. a. M9 L8 s" k6 G& t
  19.     'Address' => [& d$ v  [9 e" C/ j, P* g
  20.         'Country' => 'China',
    5 ^' n, @6 x& o" i. D' f+ B
  21.         'City' => 'Shen Zhen'0 c2 H9 b, R  f+ I& o% ?8 j
  22.     ],
    + s  l1 ^8 J! _" B  ^/ C" X
  23.     'E-Mail' => [- j+ }, S6 X2 ]% l
  24.         '123456@qq.com',9 N6 l- T3 B. ~( c* `
  25.         '666666@sina.com',
    9 X1 W* M; Y  Z: d8 S
  26.         '8888888@qq.com',
    * I6 s. V' o1 Q1 B8 _. D
  27.         '77887788@qq.com'
    2 x# Y3 v: R( x9 z  U' _
  28.     ]
    $ L" ?" j1 F7 }  e* W' Y# v- W
  29. ];) v, `0 k+ ?7 `3 _
  30. $res = $collection->save($doc);1 o5 ^$ t6 p) w! t; T
  31. echo '<pre>';
    * m6 _7 m6 U$ u8 Y1 p
  32. print_r($res);//$res['ok']=1表示操作成功,$res['updatedExisting']=1表示更新,$res['upserted']=1表示插入( }7 J; o( e, M, L4 g
  33. ( a- p7 V; l. R, j
复制代码
  1. //findAndModify()8 X" `1 f+ U* W4 s8 H
  2. //参数1:指定查询条件
    " `1 b4 z5 Z; W0 l& e' ^
  3. //参数2:指定用于更新文档的信息  N: f" {+ v% t- d1 S3 t, E
  4. //参数3:可选,指定希望返回的字段
    : O7 M% X) q$ f
  5. //参数4:扩展选项- i' W: h" d( a* F1 G: m
  6. //  sort:以特定顺序对匹配文档进行排序
    3 l7 M5 u% s. O+ {" C+ N) P" a8 f( L8 d8 e
  7. //  remove:若设置为true,第一个匹配文档将被删除0 k: O( O1 _4 K  X6 m$ x
  8. //  update:若设置为true,将在被选择的文档上执行更新操作/ t* b% j. F0 [' a4 s, A9 w+ v
  9. //  new:默认为false,若设置为true则返回更新后的文档,否则返回更新前的文档- r3 b3 I1 j- w& _1 J; [
  10. //  upsert:若设置为true,没有找到匹配文档的时候将插入一个新的文档9 z$ u+ b6 r0 C. B
  11. $mongo = new MongoClient('mongodb://localhost:27017');
    - b$ ]2 W8 M6 R  k8 k
  12. $db = $mongo->mf;
    - W. Y+ @  Z6 C% l0 d
  13. $collection = $db->friend;
    5 c% u+ P9 ]9 \% Y( w; A
  14. $res = $collection->findAndModify(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '111@qq.com']]);
    $ k" x8 P& r# K4 H6 L
  15. echo '<pre>';5 k5 J" b- A8 X! j3 E
  16. print_r($res);
复制代码
  
四、数据删除
  1. //remove()
    ' w# G& i" e" K# V
  2. //参数1:查询条件4 F  q0 q/ \' r; N
  3. //参数2:扩展选项( Z3 c$ x, d' ^0 t( E
  4. //  justOne:若设置为true,则最多只有一个匹配的文档将被删除2 e& |7 W/ I# ?9 G
  5. //  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。5 j3 |! L* F9 v% o
  6. //  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作- P8 g/ A8 N- X+ ?4 Q/ y
  7. //  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。: }) `2 [  B+ T/ _$ C
  8. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
    6 u+ M# V2 x9 D1 X3 f3 k! S' W0 }
  9. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒). L! Z; f; U6 U/ X* v: a$ z
  10. $mongo = new MongoClient('mongodb://localhost:27017');/ ~6 @0 U" O3 r+ N7 `
  11. $db = $mongo->mf;
    7 ~- P0 u. W0 h1 Z
  12. $collection = $db->friend;
    # ^9 j# x/ @* `' w& S( d
  13. $res = $collection->remove(['First Name' => 'jet']);& V. D+ H. s  ?2 ~" h. M1 m
  14. echo '<pre>';) `+ @! v' t' W( Q7 ^
  15. print_r($res);//$res['n']表示删除了几个文档
复制代码
" u1 z' m8 H6 ?4 c- G2 k! i- y0 M) z
以上是PHP7以前版本的MongoDB操作,下面简单介绍PHP7以后版本的操作。

6 D9 g- @2 \. c& e8 g$ t( p
-----------------------------------------------PHP7分隔线---------------------------------------------------------------------
4 c2 Q; X+ Q2 h8 q5 N# C
数据插入:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');' ]7 I+ i  C- `0 H- c0 w  A, }% @! Z
  2. $bulk = new MongoDB\Driver\BulkWrite;; X2 A' M/ t$ f  D3 q, ~# N1 U% A2 W
  3. $bulk->insert(['name' => 'JetWu5', 'age' => 26]);
    ! f# j; ^8 U; B2 c0 b
  4. $bulk->insert(['name' => 'JetWu6', 'age' => 26]);
    4 _! o3 z" N2 k, C$ A
  5. ) Z! Q( ^& }# H9 F
  6. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认8 M. w, W+ s: U) k2 ~+ U
  7. $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);
    + ?* k0 h# a( |4 V
  8. echo '<pre>';! X+ k' L( j6 j  l
  9. print_r($res);
复制代码

. W! f& p  o) ]  Q
数据查询:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');
    ( Z  T0 r& z: s8 \7 ]) U
  2. $query = new MongoDB\Driver\Query(['age' => 24], ['sort' => ['age' => 1]]);! i+ F$ b. M0 T6 E/ N! n; G& V" x- o
  3. $cursor = $manager->executeQuery('wjt.friend', $query);5 ?/ S  [5 ]' g3 [+ f4 b

  4. - _' u0 ?2 _2 v4 E+ X- L* U
  5. $data = [];
      L8 {- D7 x! k8 e
  6. foreach($cursor as $doc) {  o7 d* V& v- E$ J
  7.     $data[] = $doc;
    3 @, @5 s; k2 a9 u
  8. }' e1 g# c9 E: T3 _3 c9 G2 f
  9. echo '<pre>';
    & y5 b3 E5 h& T
  10. print_r($data);
复制代码
  
数据修改:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');7 i# r  H# L* o+ k+ T
  2. $bulk = new MongoDB\Driver\BulkWrite;
    + W# i; w) f- D' M
  3. $bulk->update(7 o" f0 a$ x. c/ ~7 L
  4.     ['name' => 'JetWu5'],
    ' ~0 N7 x" b2 Q4 g, j+ o/ t
  5.     ['$set' => ['age' => 30, 'promise' => 'always smile!']]- v" x" w2 ?+ W5 R  h
  6. );
    3 P; J, e& ?! X+ a
  7. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认/ ^- U- T9 S/ x9 h# c" I
  8. $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);' F4 P7 A) W+ \. G! v0 `
  9. echo '<pre>';* n, }: ]2 g0 e8 |$ |8 F% W- ^
  10. print_r($res);
复制代码
  
数据删除:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');' r8 V; p; G4 P) p6 N' Y
  2. $bulk = new MongoDB\Driver\BulkWrite;
    + M6 ^# ~1 s! X! ]8 ~4 R/ N
  3. $bulk->delete(['name' => 'JetWu3']);+ F  J. u' ?. |( {" ~0 |" Y' Y3 Z
  4. $bulk->delete(['name' => 'JetWu4']);
    1 U6 {! q  S2 K0 a& `% X; V% L
  5. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认
    ) C+ ~5 |. i% k& v
  6. $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);/ R! c. f+ Y4 Y% E* p3 n
  7. echo '<pre>';& }* }; J1 }5 J  B. ~  Y
  8. print_r($res);
复制代码

$ m" R- I: @6 R9 s/ _, j
0 P& u" B- }. d* l/ f5 m; }7 t  R
7 c2 `) Y' x( R8 @

, t! p0 u1 a1 _$ ]& a
7 g) J. x/ K5 |% k5 b1 x+ d( b7 m! i$ e
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2024-12-22 15:57 , Processed in 0.132672 second(s), 20 queries .

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