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

QQ登录

只需一步,快速开始

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 13072|回复: 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()
    ! `' N/ k; X3 C* t8 K1 I
  2. //参数1:一个数组或对象
    . U3 e3 g" @8 z% J$ ^
  3. //参数2:扩展选项
    6 p( \; U3 }5 b- d
  4. //  fsync:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入硬盘7 ^  q( M7 r+ @. C1 W
  5. //  j:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入日志
    ! ]$ X& q, E- C$ z9 \& z$ x- ?
  6. //  w:默认为1,写操作会被(主)服务器确认,若为0则将不会得到确认,使用复制集时设置为n用于确保主服务器将数据修改成功复制到n个节点后再确认
    1 |! y- W  l( i
  7. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
    , P4 x# z7 q1 N& i; z
  8. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
    : v7 V; ~# g6 l- A& [8 X% f
  9. $mongo = new MongoClient('mongodb://localhost:27017');
    ; b, u) A+ l5 I$ V5 x
  10. $db = $mongo->mf;//选择数据库+ [9 u/ N" J. }6 L. h& d$ }% }' t+ @
  11. $collection = $db->friend;//选择文档集合+ C/ Q: k1 C$ h; l' z6 q. |
  12. $doc = [//定义一个文档,即一个数组
    0 g$ u* v; i- z  `: o8 T+ g
  13.     'First Name' => 'Jet',
    & V$ n7 I5 W' S$ o3 m5 |" |9 V
  14.     'Last Name' => 'Wu',
    * ^% c/ x9 T8 O
  15.     'Age' => 26,
    # l- s5 e4 [& g9 S( ?
  16.     'Phone' => '110',
    / T- _1 {4 C3 b! W
  17.     'Address' => [1 \  z& v! t% r( \/ M+ S& X, c
  18.         'Country' => 'China',6 V# w/ y$ w+ t% ^" u
  19.         'City' => 'Shen Zhen'
    2 N8 P8 D" }$ y& B4 j0 U) j/ f
  20.     ],
    + ~- g) o0 N- }9 u
  21.     'E-Mail' => [
    + e4 {; G7 P, k( e' u
  22.         '123456@qq.com',
    ( {/ N* N0 H8 |+ Y, s% c$ g8 n) e
  23.         '666666@sina.com',
    ) v6 t4 p5 v! F) r4 |
  24.         '8888888@qq.com',
    + t; H/ I& a- L1 R
  25.         '77887788@qq.com'9 A8 i9 I0 z1 k2 j$ C# L
  26.     ]- ~. u5 K  w, {/ J- r* x) f( R
  27. ];
    / \; ]/ [! x! b
  28. $res = $collection->insert($doc);//向集合中插入一个文档3 c" t& d* B/ p
  29. echo '<pre>';* Z) X2 F  F/ O# i7 {  B; B) `
  30. print_r($res);//$res['ok']=1表示插入成功
复制代码
二、数据查询
1. 查询单个文档:
  1. //findOne()+ p# G% ]" e0 q* E/ ]9 o; J
  2. //参数1:搜索条件
    & S/ \5 M8 Q. C1 Q: h4 {( {+ x; w
  3. //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非在第二个参数显式加入'_id'=>false。不设置则返回所有字段
    1 p: U9 q9 ^& {  W4 [' }) k
  4. $mongo = new MongoClient('mongodb://localhost:27017');. P2 W5 W: b2 V5 v; r2 l4 l  `" h+ l
  5. $db = $mongo->mf;3 C+ _4 r/ d+ `+ q
  6. $collection = $db->friend;
    8 G$ e; {( I' [  T8 x9 c
  7. $one = $collection->findOne(['First Name' => 'Jet']);# O% E& x9 K2 P) E. R0 G
  8. echo '<pre>';4 ?3 m- G5 S- l( k# Z3 b, P
  9. print_r($one);//返回一个数组,查不到数据则返回NULL
复制代码
2. 查询多个文档:
  1. //find()
    ; d5 _$ ~' P9 L3 i: ]4 q, u
  2. //参数1:搜索条件( ?8 E0 B8 Z9 h  u2 N
  3. //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非显式设置为false不返回。不设置则返回所有字段
    + |6 c% w, u# I5 |: o. H! A
  4. $mongo = new MongoClient('mongodb://localhost:27017');
    $ f. Z& [2 P# S9 g0 c) x% ~, U* ?
  5. $db = $mongo->mf;
    " y* l! c# A2 q* J* I( u9 U
  6. $collection = $db->friend;6 x% {6 S" \/ \* A0 ^
  7. $cursor = $collection->find(['Address.Country' => 'China']);//使用点操作符查找数组元素
    - {: ?) p) o# n
  8. echo '<pre>';- [# q3 _3 X+ f$ a: @
  9. while($doc = $cursor->getNext()) {//循环读取每个匹配的文档$ D& S) l# V2 |/ V1 L
  10.     print_r($doc);
    2 e3 F8 f3 }1 ~9 ?
  11. }
复制代码
使用各种条件操作符定义查询:
  1. //mongodb分别使用$lt(小于)、$lte(下雨等于)、$eq(等于)、$gte(大于等于)、$gt(大于)、$ne(不等于)表示<、<=、=、>=、>、<>,用于整数字段查询7 _% C5 e9 ~, O$ S4 ^( {7 j* z  c- G5 N( R
  2. $mongo = new MongoClient('mongodb://localhost:27017');
      H) {% n7 z: f' J
  3. $db = $mongo->mf;6 L% B5 j* J* I) P
  4. $collection = $db->friend;5 J# R$ Q8 S; x
  5. $cursor = $collection->find(['Age' => ['$gt' => 30]]);
    9 Z, S! Z, D8 f0 f
  6. echo '<pre>';
    & s* _: U# s! P1 v! a
  7. while($doc = $cursor->getNext()) {
    / W$ _+ r& b. R1 d! U6 S  T7 w
  8.     print_r($doc);
    # Z, a) H- \" d2 |& S! i  }+ a
  9. }
复制代码
  //查询某个字段的所有不重复的值) T9 X6 d" \5 N, e# D2 ?
  $res = $collection->distinct('Age');
  1. //$in:匹配多个值中任意一个. ^. x- C% Z) @# V% @
  2. $cursor = $collection->find(['Address.Country' => ['$in' => ['China', 'USA']]]);3 o4 Z( A" C+ u7 h
  3. 7 f0 a; R$ U8 d- {1 u4 A
  4. //$all:匹配多个值中所有值(用于数组字段查询)
    6 W9 l, I& u% o- v' k$ B
  5. $cursor = $collection->find(['E-Mail' => ['$all' => ['123456@qq.com', '77887788@qq.com']]]);
    ' [" u2 N6 S7 L! B9 o! \
  6. % p" j! `' Z/ c3 J, v) i
  7. //$or:或查询
    ( z8 Z% G6 t# N3 a
  8. $cursor = $collection->find(['$or' => [['First Name' => 'Jet'], ['Address.Country' => 'USA']]]);
      h" s" V9 _9 Y% Z/ P  b

  9. 4 X& G0 ^/ P* {
  10. //$slice:获取数组字段中指定数目的元素,位于find()函数第二个参数中
    8 c9 E! w/ {8 @- d( |
  11. $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => 2]]);//只返回前两个email8 b6 S  [4 S! e& ]( E/ w1 R' I
  12. $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => -2]]);//只返回最后两个email
    " }4 M; }: Y* n$ w, A8 S
  13. $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => [1, 2]]]);//忽略第一个,返回接下来两个3 ~( h0 g& q- O1 P! l& s
  14. 4 y' t0 I& c5 e4 v; [9 H' F) e
  15. //$exists:根据某个字段是否有设置值进行查询
    % Q* _# h$ B0 R1 [  n% z- T# ~
  16. $cursor = $collection->find(['Hobby' => ['$exists' => false]]);//查找Hobby字段未设置值的文档
    : ^8 ^3 {, J& c$ f, `. G

  17. / q5 `" t2 @; D+ T0 E, C( ], z
  18. //正则表达式查询
    * J0 t# j, D& @, j/ U8 B
  19. $cursor = $collection->find(['First Name' => new MongoRegex('/^Je/i')]);//查找First Name字段以Je开头的文档,忽略大小写差异
复制代码
使用MongoCursor类提供的其他函数:
  1. //排序:1升序,-1降序1 d% k5 ^2 A% y% Y# a2 Z
  2. $cursor->sort(['Age' => 1]);: ]8 X: z: l0 V1 t5 u8 L- b* x
  3. / [1 L$ \$ U0 m( l2 @: m0 z
  4. //忽略前n个匹配的文档
    / H, R) B9 t$ f; L( [3 k, h! E
  5. $cursor->skip(1);
    5 T" M8 X) j. O

  6. - h, t: y& ~& B, s7 L
  7. //只返回前n个匹配的文档(limit()与skip()结合使用可实现数据分页功能)
    7 @# P5 k& [! s2 B
  8. $cursor->limit(1);
    7 v1 f+ q' V6 V: M( m& S
  9. . e  d4 s0 k7 X6 E2 K8 c3 N
  10. //匹配文档的总数7 D) `( u4 e: K
  11. $cursor->count();  c2 d  _' _# z% z' S
  12. 3 U5 D& t- n4 L  X6 T
  13. //指定查询索引& j( q8 j+ x1 A+ x
  14. $cursor->hint(['Last Name' => -1]);//若索引不存在则会报错
复制代码
聚集查询:对数据进行分组统计
  1. //聚合查询:对数据进行分组统计* h) N' L, ^' J; s: P
  2. $mongo = new MongoClient('mongodb://localhost:27017');
    * }9 m. C5 |# I) S1 U9 a
  3. $db = $mongo->mf;
    1 a. q1 j9 a; D2 g, `4 v1 Z+ G
  4. $collection = $db->friend;
    ' _* n* L# q. P
  5. $res = $collection->aggregate([. Z) Q0 c, K& X- Q% r  Q% a5 |* @9 p
  6.     '$group' => [
    $ C0 |4 u  E  U4 b- @3 c
  7.         '_id' => '$Address.Country',//分组字段,注意要加上“$”,这里是根据数组字段某个元素值进行分组
    3 M9 {# j% J: d( T- |7 M
  8.         'total' => ['$sum' => 1],//求总和,表示每匹配一个文档总和就加1
    ; _6 y& e1 }4 S4 f) n) z9 |
  9.         'maxAge' => ['$max' => '$Age'],//分组中Age字段最大值
    8 E0 N3 O  o: L* M
  10.         'minAge' => ['$min' => '$Age']//分组中Age字段最小值* k( ^# j1 l/ ~) @, K+ }1 w  @
  11.     ]6 z  X! y4 B$ H6 N( V; ~$ p
  12. ]);& W) ^/ \2 g) N, }) U
  13. echo '<pre>';* S; j+ a/ u% S- T9 l6 ]
  14. print_r($res);//返回一个数组,$ret['result']为数组,存放统计结果
    % Y- g; \; R5 \0 C8 `" q! Y8 z

  15. ( Y& o3 O) j% P( A7 H

  16. 7 c3 {% u7 y/ s' i( `
  17. //存在其它操作的聚合查询:多个操作之间执行先后顺序取决于它们位置的先后顺序
    " Y1 |$ b; G, x2 _* M
  18. //聚合查询中的所有操作,包括'$group'在内,都是可选的。
      S1 ~& |" z* x) ]* t5 M; g
  19. $mongo = new MongoClient('mongodb://localhost:27017');
    + B! X7 t0 M, z
  20. $db = $mongo->mf;" H5 |) W) O/ n, P% f
  21. $collection = $db->friend;: c0 o+ F2 N, e& c
  22. $res = $collection->aggregate([
    $ ]  L( M! Z9 z5 b7 R* `
  23.     [//过滤条件:只对符合条件的原始文档进行聚合运算,若是放在'$group'之后则是只返回符合条件的结果文档% x# I5 s% q8 J1 j
  24.         '$match' => ['Age' => ['$gt' => 30]]
      t, v2 d  }  V+ J. o! h
  25.     ],& b( U. b: ]/ ~: A, F
  26.     [//指定分组字段、统计字段" R+ R& |9 T( m* m" e' V
  27.         '$group' => [
    " d' q1 [, x  Z* d
  28.             '_id' => '$Address.Country',
    5 M0 {# M5 r; a. z& S  }  v- _
  29.             'totalAge' => ['$sum' => '$Age']//计算各个分组Age字段总和
    1 x% [$ O% W' |: K% a# f
  30.         ]
    0 x& X  c7 g% ]* Q4 B3 I
  31.     ],. c+ ^; E( W5 H) o, \5 B' b; w2 b
  32.     //以下操作若是放在'$group'之前则在聚合前作用于原始文档,若放在'$group'之后则在聚合后作用于结果文档0 v& d1 _: O# \# j7 `# n
  33.     ['$unwind' => '$E-Mail'],//将包含有某个数组类型字段的文档拆分成多个文档,每个文档的同名字段的值为数组中的一个值。
    " [8 g+ i3 }, b7 A' t+ o  e0 d
  34.     ['$project' => ['myAge' => '$Age', 'First Name' => '$First Name']],//指定返回字段,可以对字段进行重命名,格式:返回字段名 => $原来字段名
    9 @, z  N" D/ Z3 b: [2 P9 s# Z
  35.     ['$skip' => 2],//跳过指定数量的文档
    ; a; N2 A5 p7 p! c8 ?
  36.     ['$limit' => 2],//只返回指定数量的文档8 s3 @) K2 j* C' V5 X$ s1 V: ~
  37.     ['$sort' => ['totalAge' => 1]]//排序
    . [2 n& j: b2 }1 O8 N
  38. ]);
    6 v; l/ P0 G  C- _' d  |. I" @
  39. echo '<pre>';
    5 D( a# Z* J" A. d+ A
  40. print_r($res);
复制代码
3 J. X, `. Q1 I; _% Y
三、数据修改
  1. //update()% B; Z  W! _( E" F3 _
  2. //参数1:更新条件,指定更新的目标对象。' a& P3 S7 R/ r, H" [' J
  3. //参数2:指定用于更新匹配记录的对象。; K8 `7 }' l4 z6 i
  4. //参数3:扩展选项组。
    4 L4 r, U) d& N
  5. //  upsert:若设置为true,当没有匹配文档的时候会创建一个新的文档。$ U  A$ e$ W( }$ T. o
  6. //  multiple:默认为false,若设置为true,匹配文档将全部被更新。" s2 P) C+ H) t6 U2 \; n
  7. //  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。
    * H& r, l: x$ o+ C; d  y
  8. //  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作" {. M! }3 [  Y& F& s
  9. //  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
    4 f+ Z% o/ a! L7 F! l6 L% E0 I9 W
  10. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间6 L5 H/ p* P, W& g5 l" N
  11. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒): x8 |0 I$ H8 ?
  12. //注意:若不使用任何修改操作符,则匹配文档将直接被整个替换为参数2指定的对象。; n+ l2 A6 [1 G3 g5 G

  13. * `# Y7 I. B. c( K6 F% {
  14. //$inc:增加特定键的值,若字段不存在则新建字段并赋值. @. h8 A1 B3 O/ d& e, x
  15. $mongo = new MongoClient('mongodb://localhost:27017');9 L4 u( `- Y+ Q8 a% N5 G
  16. $db = $mongo->mf;8 ?6 ]2 j! z5 ?# S
  17. $collection = $db->friend;
    0 J5 f. T$ w' D& N/ m
  18. $res = $collection->update(['First Name' => 'Jet'], ['$inc' => ['Age' => 2]]);
    8 d8 R6 L0 t0 x0 A; k
  19. echo '<pre>';
    , J4 F. w& Y" S% n8 p# M
  20. print_r($res);//$res['ok']=1表示修改成功,$res['nModified']表示修改的文档数量
    6 |. M. k0 M$ I9 x* @8 \
  21. % C3 p* }# H. a- G
  22. //$set:重置特定键的值,若字段不存在则新建字段并赋值
    ) v7 k  @0 F0 q. ?
  23. $res = $collection->update(['First Name' => 'Jet'], ['$set' => ['Hobby' => 'pingpong']]);8 ~* c9 g- D/ w$ w6 O% E9 s
  24. ! Z* j. \( j% P7 R$ p- i* n
  25. //$unset:删除字段
    + I  M% {2 P/ v" i! X7 J
  26. $res = $collection->update(['First Name' => 'Jet'], ['$unset' => ['Hobby' => 1]]);
    3 U8 C- @0 B- {

  27. ( t: r% W5 s. ?% R  V/ V
  28. //$rename:重命名字段,若字段不存在则不进行任何操作4 B  F8 f5 n8 s
  29. $res = $collection->update(['First Name' => 'Jet'], ['$rename' => ['Hobby' => 'hobby', 'Age' => 'age']]);8 H, X$ ]) E) `7 X5 H! i5 v
  30. //注意:如果文档中已经使用了指定名称的字段,则该字段将会被删除,然后再进行重命名操作。) e+ l8 w- p: O% b* G" y$ N

  31. 4 N6 M" T0 ~/ u
  32. //$setOnInsert:设置了upsert为true,并且发生了插入操作的时候,将某个字段设置为特定的
    2 ~$ Q" k+ ~& {6 z) y1 v
  33. $res = $collection->update(['First Name' => 'jet'], ['$setOnInsert' => ['lang' => 'English']], ['upsert' => true]);
    ! X$ i5 Q# R% r$ Z* h8 s1 J4 S

  34. 5 j! b$ t1 l9 _; f  f
  35. //$push:向指定字段添加一个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错7 j4 ?* V1 a8 o) o! V, V
  36. $res = $collection->update(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '123123@qq.com']]);
    . |$ R9 A' D+ Z) K, z* q$ K& j

  37. % d; Y' c, b9 c' t
  38. //$push:向指定字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错/ [4 ?: a* l% M" U3 N4 ^
  39. $res = $collection->update(['First Name' => 'Jet'], ['$pushAll' => ['E-Mail' => ['666@qq.com', '8888888@qq.com']]]);* y8 P4 c% d- @, H+ Q

  40. - i6 l% o5 d+ }# M! q
  41. //使用$push和$each向某个字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错& N, x/ E/ n3 k- B- {6 x& E
  42. $res = $collection->update(['First Name' => 'Jet'], ['$push' => ['E-Mail' => ['$each' => ['123123@qq.com', '666@qq.com']]]]);
    5 C( [7 C5 r  J- {8 z5 {/ ]& E

  43. " c0 \7 s& W1 |1 _, S# `1 h0 I
  44. //$addToSet:将数据添加到数组中(只在目标数组没有该数据的时候才将数据添加到数组中)& {1 r! B' o5 O
  45. $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => '123123@qq.com']]);# ^+ H. ^; G: V, G" k
  46. $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => ['$each' => ['123123@qq.com', '666@qq.com']]]]);
    / a$ {# o# b8 w/ F+ n% y$ o
  47. : p9 k. y# }! d
  48. //$pop:从数组中删除一个元素,-1表示删除第一个元素,1表示删除最后一个元素(其实负数都删除第一个元素,0或正数都删除最后一个元素)
    2 h- J  E7 V! G0 ]8 n* y
  49. $res = $collection->update(['First Name' => 'Jet'], ['$pop' => ['E-Mail' => 1]]);3 S# I! Y/ c& d  O' ?3 m- e2 X# j
  50. " `4 a' \# f! R6 N8 L
  51. //$pull:删除数组中所有指定值4 d, B9 Y) Y3 x9 N0 n* m
  52. $res = $collection->update(['First Name' => 'Jet'], ['$pull' => ['E-Mail' => '123123@qq.com']]);* g/ H* S, ~( ~7 G8 M: |
  53. # \% {" p: }" u) w- g) n
  54. //$pullAll:删除数组中多个元素的所有值7 m" W' O6 |9 @3 b; G" j$ x, ]
  55. $res = $collection->update(['First Name' => 'Jet'], ['$pullAll' => ['E-Mail' => ['123123@qq.com', '666@qq.com']]]);
复制代码
  1. //save()
    ! O' `. m- H& G$ u
  2. //参数1:希望保存的信息数组
    ( x" V7 T% d  a# s; q5 M! d
  3. //参数2:扩展选项2 V9 N! S3 \+ |
  4. //  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。' G* |, |/ X3 m  i6 O* ^
  5. //  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作, [2 }9 ?) N& c8 K( E+ t2 o
  6. //  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。' |* a1 J2 F- B$ U; w
  7. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
    3 o/ ]. d. }2 {! s( l! F' s& c/ r
  8. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)/ v3 I1 L/ F& Q0 l2 f2 x" t4 J9 q
  9. //注意:若已存在则更新,若不存在则插入;更新时使用参数1指定的信息数组替换整个文档。
    7 c. y. g2 x6 ?0 d$ K
  10. //若想更新则应该在参数1中指定_id键的值。7 y) F+ u- v" o- W1 s. O3 P
  11. $mongo = new MongoClient('mongodb://localhost:27017');
    $ U* w, M1 j) F, P- i7 s& _0 u, L6 H$ I4 `; F
  12. $db = $mongo->mf;
    - `; @6 Z! [% k' c
  13. $collection = $db->friend;
    1 N. h% k+ F  K+ s8 A) d& B* |
  14. $doc = [//定义一个文档,即一个数组. {# g( [7 a, f; w
  15.     'First Name' => 'Jet',
    2 U1 R, [  `  d3 N
  16.     'Last Name' => 'Wu',7 y$ k0 @- z( g9 z
  17.     'Age' => 26,
    ) N% c" @& W! T
  18.     'Phone' => '110',, g4 L* M! ~. r" Q6 `
  19.     'Address' => [
    , o6 @+ W: q5 K% S3 ?0 g  S
  20.         'Country' => 'China',9 R2 d9 V% v' y$ R+ R
  21.         'City' => 'Shen Zhen'
    ! J; i. g5 u* B, l
  22.     ],
    & Y' D4 h0 H- C0 j
  23.     'E-Mail' => [3 T' y1 }, Z% ?
  24.         '123456@qq.com',. V% D& W) U/ j) Q8 y
  25.         '666666@sina.com',0 y' _/ s* C8 ?$ M2 X$ R
  26.         '8888888@qq.com',
    / _8 d$ z4 p( C' s! B' H
  27.         '77887788@qq.com'
    ; S% u9 W" H/ @! W. ^" K0 }
  28.     ]- u) K" k* ?- L3 J, g
  29. ];8 Z2 C( o! E4 X# j3 U
  30. $res = $collection->save($doc);
    8 Y3 s" w' R; q  Z2 P7 ]
  31. echo '<pre>';1 u1 F* G$ ]; v4 p: r. |4 P8 h7 ]
  32. print_r($res);//$res['ok']=1表示操作成功,$res['updatedExisting']=1表示更新,$res['upserted']=1表示插入
    ; P* A! G1 U9 ?# ?1 V
  33. ! n% I% P2 D% C9 k
复制代码
  1. //findAndModify()9 y9 d) E. Z# w: X, F
  2. //参数1:指定查询条件7 L* l/ ?  i0 }
  3. //参数2:指定用于更新文档的信息' c3 s) u% I0 }# D8 |, Y/ h4 r
  4. //参数3:可选,指定希望返回的字段' U6 i* d2 d4 o( K: v
  5. //参数4:扩展选项
    , H6 l# w$ Y: w# h! S8 B
  6. //  sort:以特定顺序对匹配文档进行排序+ H+ ]+ K/ g. ?& d
  7. //  remove:若设置为true,第一个匹配文档将被删除1 h, |: L' e% n
  8. //  update:若设置为true,将在被选择的文档上执行更新操作
    : p3 `& u5 a- F5 F! K5 Q! W
  9. //  new:默认为false,若设置为true则返回更新后的文档,否则返回更新前的文档) f7 f# r3 C( |
  10. //  upsert:若设置为true,没有找到匹配文档的时候将插入一个新的文档
    9 T! D, g8 V. I3 a  }$ {% g
  11. $mongo = new MongoClient('mongodb://localhost:27017');
    ) \2 v2 \; I+ }, T
  12. $db = $mongo->mf;9 Z7 R) J# I7 g
  13. $collection = $db->friend;
    3 a% P! @2 J6 H1 x7 P- Y: Y: R
  14. $res = $collection->findAndModify(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '111@qq.com']]);
      j' T+ b9 J4 `- h
  15. echo '<pre>';
    * s' w1 ~: v5 s* w  ]' _- S
  16. print_r($res);
复制代码
  
四、数据删除
  1. //remove()3 f& z1 W& ?" Q4 C
  2. //参数1:查询条件0 @3 X% E; P% M! k1 E
  3. //参数2:扩展选项
    - `& P! T. n( S
  4. //  justOne:若设置为true,则最多只有一个匹配的文档将被删除
    . d7 `& ?" ]: g9 h
  5. //  fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。
    ( n$ S7 b* u! w7 q
  6. //  w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作/ ?& v# |' ?" H) a  O# r7 q
  7. //  j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
    / q& v- e3 X0 f$ A# i+ `6 {" X9 O
  8. //  wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间3 @7 u2 y  f  d1 `
  9. //  timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
    / g% ?2 p4 `3 Z& ]
  10. $mongo = new MongoClient('mongodb://localhost:27017');9 K5 V1 ~5 b4 k, V5 k! T7 h
  11. $db = $mongo->mf;
    . e! d2 v7 U, p: A" k8 E! s
  12. $collection = $db->friend;5 u% l! w3 O3 ?: c# p! U; y
  13. $res = $collection->remove(['First Name' => 'jet']);
    7 b8 ?2 o, C+ \4 Z1 {
  14. echo '<pre>';( @* R2 D9 C$ b$ P4 U( {& i8 L; j0 y* ~
  15. print_r($res);//$res['n']表示删除了几个文档
复制代码
/ ?( Q- O$ s% ^
以上是PHP7以前版本的MongoDB操作,下面简单介绍PHP7以后版本的操作。
: X! X5 T5 ~  @3 z! A( |0 ~. R
-----------------------------------------------PHP7分隔线---------------------------------------------------------------------

6 s& K, y# W0 L  p
数据插入:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');  z1 Y, c/ ~$ ^' T* m! \5 c
  2. $bulk = new MongoDB\Driver\BulkWrite;' L: b# N0 k$ H! `
  3. $bulk->insert(['name' => 'JetWu5', 'age' => 26]);
    8 o4 g+ h  {0 J/ p1 U! P
  4. $bulk->insert(['name' => 'JetWu6', 'age' => 26]);
    : b8 B5 w# y; M

  5. ( e" a& U+ c+ l" d( k
  6. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认
      ~0 ^# g) A5 ~: U) g- J
  7. $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);; `8 i! a- n4 A; a
  8. echo '<pre>';" ]: }( D5 T5 m4 L. K
  9. print_r($res);
复制代码
9 q2 R. X3 b' A, `& n. X( C
数据查询:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');3 d" w- m* x- E; G1 m9 N& K
  2. $query = new MongoDB\Driver\Query(['age' => 24], ['sort' => ['age' => 1]]);  F' [- A$ n* [& m; G/ N  a% c% e& [
  3. $cursor = $manager->executeQuery('wjt.friend', $query);
    4 j* @% X# R4 }, F8 c
  4. $ g( T* A( m) @" d/ w
  5. $data = [];  N) C  y3 P3 K* R9 o) }; ~! c7 P
  6. foreach($cursor as $doc) {" C* h3 m2 q6 `/ g! f! s8 O: I" H
  7.     $data[] = $doc;
    - F! S- K; Z' {1 P" g! d
  8. }' s" c8 W2 p7 A* P. v' M
  9. echo '<pre>';& Q2 U" [( y8 p# c" G; Z6 t
  10. print_r($data);
复制代码
  
数据修改:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');8 J+ Q0 Y2 _* `; P' p. H) i
  2. $bulk = new MongoDB\Driver\BulkWrite;
    ' W5 H6 c& j1 t2 q1 x) H# Q
  3. $bulk->update($ n3 w# }* t3 r$ ?. Z
  4.     ['name' => 'JetWu5'],2 ^) E4 q- U; v, @2 G' N4 e4 n
  5.     ['$set' => ['age' => 30, 'promise' => 'always smile!']]
    # M: J5 T' t, x4 ~7 |* K, C" @
  6. );
    ( n. R5 T8 c7 V4 t- X2 W
  7. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认
    6 z' ]: m: U0 p- w- V. h
  8. $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);
    . }& Y; z; B  Z
  9. echo '<pre>';
    - x2 e5 Y/ K: z8 m, T/ y
  10. print_r($res);
复制代码
  
数据删除:
  1. $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');5 g; a5 m; b$ j/ ]0 f, h& K6 u, F
  2. $bulk = new MongoDB\Driver\BulkWrite;
    $ N; }7 `4 G' n% d* r6 `
  3. $bulk->delete(['name' => 'JetWu3']);
    : x, a8 m/ T% {; U& w' b4 I& L) `
  4. $bulk->delete(['name' => 'JetWu4']);
    8 H  M7 r+ v: W5 D9 O
  5. $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认" f- w$ _+ ~8 E2 \/ Z+ m3 `5 B: X
  6. $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);8 e7 F7 ]$ B; k( r( h8 c" Q2 `! x4 H
  7. echo '<pre>';1 c8 R6 j( y% `$ D/ {
  8. print_r($res);
复制代码
5 {/ |7 ]5 N9 I+ O0 o4 h
5 X. g2 n6 d0 O0 d0 t

! ~6 n- R; [2 ]
* |' L/ T* V2 q
* T& i! C  B( H: ~% K1 d4 A0 H, d
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 支持支持 反对反对
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

GMT+8, 2026-6-20 01:18 , Processed in 0.060140 second(s), 19 queries .

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