MongoDB的PHP驱动提供了一些核心类来操作MongoDB,总的来说MongoDB命令行中有的功能,它都可以实现,而且参数的格式基本相似。PHP7以前的版本和PHP7之后的版本对MongoDB的操作有所不同,本文主要以PHP7以前版本为例讲解PHP对MongoDB的各种操作,最后再简单说明一下PHP7以后版本对MongoDB的操作。 一、数据插入 - //insert(); W! A% d, K! C$ w
- //参数1:一个数组或对象 {. H' [! i- E# Z) ^ W
- //参数2:扩展选项
0 h3 z" o w. }1 ]' Q9 L - // fsync:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入硬盘: C# H+ d5 B6 Z( E W( G
- // j:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入日志% W' v; Z* B7 a
- // w:默认为1,写操作会被(主)服务器确认,若为0则将不会得到确认,使用复制集时设置为n用于确保主服务器将数据修改成功复制到n个节点后再确认
) Z3 K& {8 z& Z* C- c - // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间! l9 W/ B+ |1 r! U: {
- // timeout:指定客户端需要等待服务器响应的超时时间(毫秒)/ F/ p8 K% n ^: F" o7 A8 `
- $mongo = new MongoClient('mongodb://localhost:27017');
* m3 q1 G7 {- d3 h4 y - $db = $mongo->mf;//选择数据库
1 e* `8 u6 ~7 Z/ f - $collection = $db->friend;//选择文档集合0 M; ~( H/ Y9 `0 i+ p5 X# z1 _* A6 R
- $doc = [//定义一个文档,即一个数组
" b" e5 z" m& k. |0 m8 z _& | - 'First Name' => 'Jet',5 \: y6 |) w+ O% h
- 'Last Name' => 'Wu',/ H6 k/ e, H4 A' n, c) G8 x
- 'Age' => 26,. w& v1 H: h, z8 N; o
- 'Phone' => '110',
' y" r3 T$ P$ @) u0 |8 ?* x8 w9 q( ^ - 'Address' => [
" o f2 t2 ~( A; m" { - 'Country' => 'China',1 T/ M# e3 @+ w5 Y7 h. Y) [2 H
- 'City' => 'Shen Zhen'
c p; N- w9 ~- {* b# E( p - ],
/ a0 h) }% P$ V. }! C/ t, H - 'E-Mail' => [* k) f, ]1 q H5 H( i
- '123456@qq.com'," r3 a; P: b( U0 S( A$ V2 v
- '666666@sina.com',
9 E1 z* T' ^1 n' b" ^" {2 R - '8888888@qq.com',! H# E" I& f* H; ? ~6 l x
- '77887788@qq.com'4 P- p% B L7 W6 x
- ]- B( \5 v% w1 k9 H1 I
- ];1 p" `; }) H3 L. f7 }
- $res = $collection->insert($doc);//向集合中插入一个文档- R6 g8 f5 |1 \$ P. d0 I
- echo '<pre>';% i/ R. n0 M4 @6 D4 v B+ H7 |5 T# I
- print_r($res);//$res['ok']=1表示插入成功
复制代码二、数据查询 1. 查询单个文档: - //findOne()/ n L( Q6 ^) [$ p0 J1 t, S
- //参数1:搜索条件
$ g$ [# A. B2 a F+ [7 ?( q; \/ o - //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非在第二个参数显式加入'_id'=>false。不设置则返回所有字段
u/ W T" u/ v - $mongo = new MongoClient('mongodb://localhost:27017');
( H0 p% c) z o. @' e/ ?- Z8 ] - $db = $mongo->mf;6 q* D/ G$ D9 W. \; g
- $collection = $db->friend;2 k) j! {, x' @, Z: g
- $one = $collection->findOne(['First Name' => 'Jet']);
! E7 }7 K* v: I, O - echo '<pre>';( Y# [! r; k3 h/ f/ y% W
- print_r($one);//返回一个数组,查不到数据则返回NULL
复制代码2. 查询多个文档: - //find()
' Z7 E9 ]( p# O) b - //参数1:搜索条件, W* L+ a+ j) b( N. X3 o9 h/ O
- //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非显式设置为false不返回。不设置则返回所有字段
3 r3 e9 U) \& \: h - $mongo = new MongoClient('mongodb://localhost:27017');
$ f! b" [# B f; \$ L* x3 ` - $db = $mongo->mf;% L, O; {7 ~5 X6 j' n6 D+ C( V
- $collection = $db->friend;' {. |" e( R0 m0 c3 k$ ]) w; P1 x
- $cursor = $collection->find(['Address.Country' => 'China']);//使用点操作符查找数组元素" f! G' U1 `9 n/ }* s& E v* Z
- echo '<pre>';: K2 f7 H1 l* j9 e! p" }, \% b3 u) G
- while($doc = $cursor->getNext()) {//循环读取每个匹配的文档
) W8 J8 k# R T4 @- j0 s/ ^ - print_r($doc);
* a& h: r( f- n' w' S5 H& P) H - }
复制代码使用各种条件操作符定义查询: - //mongodb分别使用$lt(小于)、$lte(下雨等于)、$eq(等于)、$gte(大于等于)、$gt(大于)、$ne(不等于)表示<、<=、=、>=、>、<>,用于整数字段查询+ o- D. h7 N9 s' c9 q0 h! b- g
- $mongo = new MongoClient('mongodb://localhost:27017');0 R+ ~4 Q+ u0 H
- $db = $mongo->mf;" Q3 t4 v/ X5 L* }
- $collection = $db->friend;
3 e6 W) l+ B5 ?$ B% l3 G - $cursor = $collection->find(['Age' => ['$gt' => 30]]);
7 ^; d$ w3 y0 L' y - echo '<pre>';" s% j0 s$ P+ X/ X a% }
- while($doc = $cursor->getNext()) {3 Y- W" n' O2 z: l9 C0 T
- print_r($doc);
+ {9 v* z- p6 j/ \0 g3 j& p2 G7 y - }
复制代码 //查询某个字段的所有不重复的值
2 n3 V: F# ?3 L' _ $res = $collection->distinct('Age'); - //$in:匹配多个值中任意一个
7 v+ C' @* B- n6 p - $cursor = $collection->find(['Address.Country' => ['$in' => ['China', 'USA']]]);9 f# O5 l. \5 H4 U& n" _
-
4 n+ t9 i: K% x* R) } - //$all:匹配多个值中所有值(用于数组字段查询)
a2 t# Y! K5 \- B0 I2 D1 y% g5 A( U - $cursor = $collection->find(['E-Mail' => ['$all' => ['123456@qq.com', '77887788@qq.com']]]);
7 N+ n+ E: S( Z3 w9 J -
e7 t7 e. B0 _4 `$ { - //$or:或查询4 k8 n @; s; F- @1 S5 i/ j& I9 X8 P
- $cursor = $collection->find(['$or' => [['First Name' => 'Jet'], ['Address.Country' => 'USA']]]);
H6 u( }+ A5 n -
0 }/ X5 E- B8 U5 R I( M r - //$slice:获取数组字段中指定数目的元素,位于find()函数第二个参数中( y# r9 @% |2 z
- $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => 2]]);//只返回前两个email
, w4 Y* z) }% [% E: g+ D0 ?$ d - $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => -2]]);//只返回最后两个email* ]4 s: H# p3 c- W
- $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => [1, 2]]]);//忽略第一个,返回接下来两个/ A. ^$ S& `: Z7 i- ? L
- 9 h8 m7 _4 S. c
- //$exists:根据某个字段是否有设置值进行查询
8 A% X0 Z+ {$ y3 \/ d - $cursor = $collection->find(['Hobby' => ['$exists' => false]]);//查找Hobby字段未设置值的文档
5 s+ B5 x d/ [& p e5 Z0 p/ g - , L) R" Y- Q, t1 W
- //正则表达式查询
7 [$ [; I B" _: N - $cursor = $collection->find(['First Name' => new MongoRegex('/^Je/i')]);//查找First Name字段以Je开头的文档,忽略大小写差异
复制代码使用MongoCursor类提供的其他函数: - //排序:1升序,-1降序4 p- _# Y# V* }/ d5 `/ c
- $cursor->sort(['Age' => 1]);7 q+ o& {' | z# }% [. ~9 `
- ) V% L0 {5 u: W8 ]
- //忽略前n个匹配的文档. n' A( l; l' n9 L
- $cursor->skip(1);1 b" s2 V! e& a4 T: }0 I u8 i
-
6 X8 k0 x+ z. W5 k. T+ ?7 v- I - //只返回前n个匹配的文档(limit()与skip()结合使用可实现数据分页功能)3 W# O" W2 X2 ]6 p* \4 u
- $cursor->limit(1);
2 q( `5 B! x j% i* i; n -
7 _% F* F9 g3 g0 k& R - //匹配文档的总数4 z! |! A h X% Q* R) B
- $cursor->count();8 U1 W0 ^3 g- Q# R. l
- 9 u: |& D/ Q( t3 a% X8 A( x
- //指定查询索引! J( o3 `( P3 R
- $cursor->hint(['Last Name' => -1]);//若索引不存在则会报错
复制代码聚集查询:对数据进行分组统计 - //聚合查询:对数据进行分组统计
; @" K5 |; M* z7 } p- C: R6 S - $mongo = new MongoClient('mongodb://localhost:27017'); o" o# `: _$ f, }5 ~: C
- $db = $mongo->mf;
- H$ X) N) {& R3 U - $collection = $db->friend;
& {3 ^( c: P0 }2 L0 t" K - $res = $collection->aggregate([' K6 h& p& q4 H0 d, I+ S
- '$group' => [
- S& O: }9 p3 V* t) M7 J - '_id' => '$Address.Country',//分组字段,注意要加上“$”,这里是根据数组字段某个元素值进行分组
+ z/ `0 U( Z- a) Z$ H+ i - 'total' => ['$sum' => 1],//求总和,表示每匹配一个文档总和就加1
! i6 e! L4 n! m- L9 H7 w - 'maxAge' => ['$max' => '$Age'],//分组中Age字段最大值$ x i% D% z( R( I, z+ ^& M
- 'minAge' => ['$min' => '$Age']//分组中Age字段最小值; W# d5 Y7 `0 Y! |: l, o
- ]
5 k$ X* i3 g1 W - ]);- F) k: |3 u$ y* I6 i3 q3 n
- echo '<pre>';+ ~ a* k3 C2 {: C/ k
- print_r($res);//返回一个数组,$ret['result']为数组,存放统计结果
, j) t0 H: B. C( {. r0 C - " t- }; V5 ]# W6 k5 W9 \, b. H! B
-
5 L; H$ p3 l* R, K; x1 t( e - //存在其它操作的聚合查询:多个操作之间执行先后顺序取决于它们位置的先后顺序; S" Y% y# S. H- w; Y, N
- //聚合查询中的所有操作,包括'$group'在内,都是可选的。6 j7 j. t" q8 s, s
- $mongo = new MongoClient('mongodb://localhost:27017');
, r) o' a" a; h: K - $db = $mongo->mf;
. u3 [; w/ r [2 _; _/ q' q" x - $collection = $db->friend;
' I: V8 F$ S: N. |; V- f* p - $res = $collection->aggregate([" g. [0 Z1 J5 i; d. }# G+ ~+ V
- [//过滤条件:只对符合条件的原始文档进行聚合运算,若是放在'$group'之后则是只返回符合条件的结果文档
) t3 @& X# L" z0 S - '$match' => ['Age' => ['$gt' => 30]]
' {' o+ D" z5 ], O2 d7 j$ i - ],
) X1 B- h/ d7 p/ r' ] - [//指定分组字段、统计字段
. v2 O2 h* ]. ]+ {$ i. r) F8 z3 ^ - '$group' => [
2 Y7 F! k5 J/ x- u6 N. p; ?% Q- n- @/ G - '_id' => '$Address.Country',
: D) g, a3 s8 v0 N- |. N; h - 'totalAge' => ['$sum' => '$Age']//计算各个分组Age字段总和% h+ M( i; h8 G! \% l1 C- N }
- ]) I; _+ {. N& x/ E! T
- ],
8 I# z' W5 I5 \2 y$ x" B/ C - //以下操作若是放在'$group'之前则在聚合前作用于原始文档,若放在'$group'之后则在聚合后作用于结果文档) m+ a' K) o" p' g8 M/ J6 T* V/ _
- ['$unwind' => '$E-Mail'],//将包含有某个数组类型字段的文档拆分成多个文档,每个文档的同名字段的值为数组中的一个值。
% b6 V$ Q8 W2 G - ['$project' => ['myAge' => '$Age', 'First Name' => '$First Name']],//指定返回字段,可以对字段进行重命名,格式:返回字段名 => $原来字段名& a' p& a- m3 r( @3 r
- ['$skip' => 2],//跳过指定数量的文档/ s8 W. F F) j
- ['$limit' => 2],//只返回指定数量的文档/ T' h; V: X& o# z
- ['$sort' => ['totalAge' => 1]]//排序
9 S7 F1 R7 I7 E, R# C+ f - ]);5 C/ `2 |$ u: \0 o0 y8 F
- echo '<pre>';
; d) |$ r( f& w7 @; r% | - print_r($res);
复制代码 + t5 n4 s) c( i# G# Q/ j) [% ^* n9 W) p
三、数据修改 - //update()& [, k# w- p& a4 r3 S6 f! {% w4 i
- //参数1:更新条件,指定更新的目标对象。5 l2 l ]# z/ C2 l3 i& X7 T
- //参数2:指定用于更新匹配记录的对象。) J% o2 o0 I$ u3 B
- //参数3:扩展选项组。
" D8 M! Z% K) ~ - // upsert:若设置为true,当没有匹配文档的时候会创建一个新的文档。
1 e- B0 x5 U J. {% Y9 V. b' q" I - // multiple:默认为false,若设置为true,匹配文档将全部被更新。! Z9 G" d/ u; t8 {
- // fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。- _* I; `: e% Y
- // w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作
7 q( s% \" v) F1 I - // j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。6 X. n& V9 a4 ?
- // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间; r+ W& V. \) \. S. i9 Z! Q; S4 }
- // timeout:指定客户端需要等待服务器响应的超时时间(毫秒)" q$ k. }- l4 i- ~* `/ y
- //注意:若不使用任何修改操作符,则匹配文档将直接被整个替换为参数2指定的对象。: K1 n2 @# F3 E# G/ Z1 ~, S! O% T
-
! t) P! W! Q6 [- y% b" W - //$inc:增加特定键的值,若字段不存在则新建字段并赋值
( Q6 W. I) S! A4 c0 e# d - $mongo = new MongoClient('mongodb://localhost:27017');
) ^) O; ? r& q$ a' e - $db = $mongo->mf;
/ S* U/ g: n3 I4 n - $collection = $db->friend;! n* u: t g% X" \1 K
- $res = $collection->update(['First Name' => 'Jet'], ['$inc' => ['Age' => 2]]);
- Z1 [& g- F! L7 t G - echo '<pre>';
& T$ r9 @! \8 l* v, d3 e - print_r($res);//$res['ok']=1表示修改成功,$res['nModified']表示修改的文档数量
7 k. d! _! [+ E ~' t3 _( T - ' F I4 b' w O
- //$set:重置特定键的值,若字段不存在则新建字段并赋值7 \/ k/ r+ s( c# O
- $res = $collection->update(['First Name' => 'Jet'], ['$set' => ['Hobby' => 'pingpong']]);6 V' j& m/ I2 u/ y4 ?1 U
-
I& }% D/ n/ L' }( |4 B) d% | - //$unset:删除字段
: L3 N* \7 a3 ?! b# z/ C5 t - $res = $collection->update(['First Name' => 'Jet'], ['$unset' => ['Hobby' => 1]]);. y5 x, }8 g/ [! }. O; x2 f. g
-
. w0 Y y$ l$ E4 k9 @8 k) [4 ^ - //$rename:重命名字段,若字段不存在则不进行任何操作! C- U' z# k9 h
- $res = $collection->update(['First Name' => 'Jet'], ['$rename' => ['Hobby' => 'hobby', 'Age' => 'age']]);3 i B' d$ s$ A6 r% {
- //注意:如果文档中已经使用了指定名称的字段,则该字段将会被删除,然后再进行重命名操作。
9 X7 f7 F/ U. t0 Y" x! A8 _' W1 ] W -
# V1 J9 k. j; T `( n. P - //$setOnInsert:设置了upsert为true,并且发生了插入操作的时候,将某个字段设置为特定的3 k" i$ i9 l$ N! Q$ R! z$ V
- $res = $collection->update(['First Name' => 'jet'], ['$setOnInsert' => ['lang' => 'English']], ['upsert' => true]);
7 G/ ]1 ~- m) H+ ^1 M - : ~4 h8 E9 r8 ~
- //$push:向指定字段添加一个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错( y. t ~' E! Y$ l
- $res = $collection->update(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '123123@qq.com']]);
\- t, p; w# d - ) O- i t( b# i+ t
- //$push:向指定字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错
$ b4 w) z+ j! a" J' q2 B - $res = $collection->update(['First Name' => 'Jet'], ['$pushAll' => ['E-Mail' => ['666@qq.com', '8888888@qq.com']]]);" ]1 x+ Y5 u" v# M' }
- " y1 i- K( ~8 H" U+ g. a
- //使用$push和$each向某个字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错
+ g2 w" O6 r$ P4 h - $res = $collection->update(['First Name' => 'Jet'], ['$push' => ['E-Mail' => ['$each' => ['123123@qq.com', '666@qq.com']]]]);
( K0 F, f- M2 K' K0 p: I7 { -
7 o) W3 e7 |, w1 }1 b/ P - //$addToSet:将数据添加到数组中(只在目标数组没有该数据的时候才将数据添加到数组中)2 F: H: [, B6 ^5 M1 N" p
- $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => '123123@qq.com']]);: k7 T8 H! r. D* f- |* P# o
- $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => ['$each' => ['123123@qq.com', '666@qq.com']]]]);
0 |+ V3 J; o5 U1 K - 9 c' X, F- Q' f: k
- //$pop:从数组中删除一个元素,-1表示删除第一个元素,1表示删除最后一个元素(其实负数都删除第一个元素,0或正数都删除最后一个元素)! F: Q( q9 ?9 q9 D
- $res = $collection->update(['First Name' => 'Jet'], ['$pop' => ['E-Mail' => 1]]);
( }. j- A% J7 [/ `( Z# z. K* y - ) Y$ H+ z' W8 U6 |" ?
- //$pull:删除数组中所有指定值9 n- P+ v) v4 n. W' Y+ ]
- $res = $collection->update(['First Name' => 'Jet'], ['$pull' => ['E-Mail' => '123123@qq.com']]);5 b2 |" K, J( \
- , P' p3 Z: R. v, V: D
- //$pullAll:删除数组中多个元素的所有值1 a0 Y" u/ k- a7 ^( d
- $res = $collection->update(['First Name' => 'Jet'], ['$pullAll' => ['E-Mail' => ['123123@qq.com', '666@qq.com']]]);
复制代码- //save()$ ^, f6 I! ?& K) V+ o; K' d/ \
- //参数1:希望保存的信息数组
* y+ f; t- T7 e9 S% i( S/ h - //参数2:扩展选项
; @: E: X, G) x0 J* p - // fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。/ ^* T. N4 i% u6 \
- // w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作* j1 ?3 a$ w' L2 p; q
- // j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
5 g% `+ @0 B$ d - // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间6 Z1 E0 ~) Z+ A) c' R
- // timeout:指定客户端需要等待服务器响应的超时时间(毫秒)! q/ H: w* q+ |0 X# b8 ^
- //注意:若已存在则更新,若不存在则插入;更新时使用参数1指定的信息数组替换整个文档。: V7 \2 W3 S! h; M1 q
- //若想更新则应该在参数1中指定_id键的值。3 C& ^( [' C5 }7 K
- $mongo = new MongoClient('mongodb://localhost:27017');* b3 g, j! g1 V9 x
- $db = $mongo->mf;
: O* v& u) J/ X0 z0 S: o) s7 s - $collection = $db->friend;
( D0 X6 W% u* U6 C6 r6 _ - $doc = [//定义一个文档,即一个数组
7 | E# s) M: y) k6 J8 ?' J - 'First Name' => 'Jet',* N3 V/ e$ K2 T. m2 Q A
- 'Last Name' => 'Wu',
* B S. J, [5 b - 'Age' => 26,
5 @4 c4 i; @' [/ Y6 e3 Y: z - 'Phone' => '110',. a. M9 L8 s" k6 G& t
- 'Address' => [& d$ v [9 e" C/ j, P* g
- 'Country' => 'China',
5 ^' n, @6 x& o" i. D' f+ B - 'City' => 'Shen Zhen'0 c2 H9 b, R f+ I& o% ?8 j
- ],
+ s l1 ^8 J! _" B ^/ C" X - 'E-Mail' => [- j+ }, S6 X2 ]% l
- '123456@qq.com',9 N6 l- T3 B. ~( c* `
- '666666@sina.com',
9 X1 W* M; Y Z: d8 S - '8888888@qq.com',
* I6 s. V' o1 Q1 B8 _. D - '77887788@qq.com'
2 x# Y3 v: R( x9 z U' _ - ]
$ L" ?" j1 F7 } e* W' Y# v- W - ];) v, `0 k+ ?7 `3 _
- $res = $collection->save($doc);1 o5 ^$ t6 p) w! t; T
- echo '<pre>';
* m6 _7 m6 U$ u8 Y1 p - print_r($res);//$res['ok']=1表示操作成功,$res['updatedExisting']=1表示更新,$res['upserted']=1表示插入( }7 J; o( e, M, L4 g
- ( a- p7 V; l. R, j
复制代码- //findAndModify()8 X" `1 f+ U* W4 s8 H
- //参数1:指定查询条件
" `1 b4 z5 Z; W0 l& e' ^ - //参数2:指定用于更新文档的信息 N: f" {+ v% t- d1 S3 t, E
- //参数3:可选,指定希望返回的字段
: O7 M% X) q$ f - //参数4:扩展选项- i' W: h" d( a* F1 G: m
- // sort:以特定顺序对匹配文档进行排序
3 l7 M5 u% s. O+ {" C+ N) P" a8 f( L8 d8 e - // remove:若设置为true,第一个匹配文档将被删除0 k: O( O1 _4 K X6 m$ x
- // update:若设置为true,将在被选择的文档上执行更新操作/ t* b% j. F0 [' a4 s, A9 w+ v
- // new:默认为false,若设置为true则返回更新后的文档,否则返回更新前的文档- r3 b3 I1 j- w& _1 J; [
- // upsert:若设置为true,没有找到匹配文档的时候将插入一个新的文档9 z$ u+ b6 r0 C. B
- $mongo = new MongoClient('mongodb://localhost:27017');
- b$ ]2 W8 M6 R k8 k - $db = $mongo->mf;
- W. Y+ @ Z6 C% l0 d - $collection = $db->friend;
5 c% u+ P9 ]9 \% Y( w; A - $res = $collection->findAndModify(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '111@qq.com']]);
$ k" x8 P& r# K4 H6 L - echo '<pre>';5 k5 J" b- A8 X! j3 E
- print_r($res);
复制代码 四、数据删除 - //remove()
' w# G& i" e" K# V - //参数1:查询条件4 F q0 q/ \' r; N
- //参数2:扩展选项( Z3 c$ x, d' ^0 t( E
- // justOne:若设置为true,则最多只有一个匹配的文档将被删除2 e& |7 W/ I# ?9 G
- // fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。5 j3 |! L* F9 v% o
- // w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作- P8 g/ A8 N- X+ ?4 Q/ y
- // j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。: }) `2 [ B+ T/ _$ C
- // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
6 u+ M# V2 x9 D1 X3 f3 k! S' W0 } - // timeout:指定客户端需要等待服务器响应的超时时间(毫秒). L! Z; f; U6 U/ X* v: a$ z
- $mongo = new MongoClient('mongodb://localhost:27017');/ ~6 @0 U" O3 r+ N7 `
- $db = $mongo->mf;
7 ~- P0 u. W0 h1 Z - $collection = $db->friend;
# ^9 j# x/ @* `' w& S( d - $res = $collection->remove(['First Name' => 'jet']);& V. D+ H. s ?2 ~" h. M1 m
- echo '<pre>';) `+ @! v' t' W( Q7 ^
- 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
数据插入: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');' ]7 I+ i C- `0 H- c0 w A, }% @! Z
- $bulk = new MongoDB\Driver\BulkWrite;; X2 A' M/ t$ f D3 q, ~# N1 U% A2 W
- $bulk->insert(['name' => 'JetWu5', 'age' => 26]);
! f# j; ^8 U; B2 c0 b - $bulk->insert(['name' => 'JetWu6', 'age' => 26]);
4 _! o3 z" N2 k, C$ A - ) Z! Q( ^& }# H9 F
- $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认8 M. w, W+ s: U) k2 ~+ U
- $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);
+ ?* k0 h# a( |4 V - echo '<pre>';! X+ k' L( j6 j l
- print_r($res);
复制代码
. W! f& p o) ] Q数据查询: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');
( Z T0 r& z: s8 \7 ]) U - $query = new MongoDB\Driver\Query(['age' => 24], ['sort' => ['age' => 1]]);! i+ F$ b. M0 T6 E/ N! n; G& V" x- o
- $cursor = $manager->executeQuery('wjt.friend', $query);5 ?/ S [5 ]' g3 [+ f4 b
-
- _' u0 ?2 _2 v4 E+ X- L* U - $data = [];
L8 {- D7 x! k8 e - foreach($cursor as $doc) { o7 d* V& v- E$ J
- $data[] = $doc;
3 @, @5 s; k2 a9 u - }' e1 g# c9 E: T3 _3 c9 G2 f
- echo '<pre>';
& y5 b3 E5 h& T - print_r($data);
复制代码 数据修改: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');7 i# r H# L* o+ k+ T
- $bulk = new MongoDB\Driver\BulkWrite;
+ W# i; w) f- D' M - $bulk->update(7 o" f0 a$ x. c/ ~7 L
- ['name' => 'JetWu5'],
' ~0 N7 x" b2 Q4 g, j+ o/ t - ['$set' => ['age' => 30, 'promise' => 'always smile!']]- v" x" w2 ?+ W5 R h
- );
3 P; J, e& ?! X+ a - $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认/ ^- U- T9 S/ x9 h# c" I
- $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);' F4 P7 A) W+ \. G! v0 `
- echo '<pre>';* n, }: ]2 g0 e8 |$ |8 F% W- ^
- print_r($res);
复制代码 数据删除: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');' r8 V; p; G4 P) p6 N' Y
- $bulk = new MongoDB\Driver\BulkWrite;
+ M6 ^# ~1 s! X! ]8 ~4 R/ N - $bulk->delete(['name' => 'JetWu3']);+ F J. u' ?. |( {" ~0 |" Y' Y3 Z
- $bulk->delete(['name' => 'JetWu4']);
1 U6 {! q S2 K0 a& `% X; V% L - $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认
) C+ ~5 |. i% k& v - $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);/ R! c. f+ Y4 Y% E* p3 n
- echo '<pre>';& }* }; J1 }5 J B. ~ Y
- 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 |