|
MongoDB的PHP驱动提供了一些核心类来操作MongoDB,总的来说MongoDB命令行中有的功能,它都可以实现,而且参数的格式基本相似。PHP7以前的版本和PHP7之后的版本对MongoDB的操作有所不同,本文主要以PHP7以前版本为例讲解PHP对MongoDB的各种操作,最后再简单说明一下PHP7以后版本对MongoDB的操作。 一、数据插入 - //insert()
! `' N/ k; X3 C* t8 K1 I - //参数1:一个数组或对象
. U3 e3 g" @8 z% J$ ^ - //参数2:扩展选项
6 p( \; U3 }5 b- d - // fsync:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入硬盘7 ^ q( M7 r+ @. C1 W
- // j:默认为false,若为true则mongo在确认数据插入成功之前将会强制把数据写入日志
! ]$ X& q, E- C$ z9 \& z$ x- ? - // w:默认为1,写操作会被(主)服务器确认,若为0则将不会得到确认,使用复制集时设置为n用于确保主服务器将数据修改成功复制到n个节点后再确认
1 |! y- W l( i - // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
, P4 x# z7 q1 N& i; z - // timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
: v7 V; ~# g6 l- A& [8 X% f - $mongo = new MongoClient('mongodb://localhost:27017');
; b, u) A+ l5 I$ V5 x - $db = $mongo->mf;//选择数据库+ [9 u/ N" J. }6 L. h& d$ }% }' t+ @
- $collection = $db->friend;//选择文档集合+ C/ Q: k1 C$ h; l' z6 q. |
- $doc = [//定义一个文档,即一个数组
0 g$ u* v; i- z `: o8 T+ g - 'First Name' => 'Jet',
& V$ n7 I5 W' S$ o3 m5 |" |9 V - 'Last Name' => 'Wu',
* ^% c/ x9 T8 O - 'Age' => 26,
# l- s5 e4 [& g9 S( ? - 'Phone' => '110',
/ T- _1 {4 C3 b! W - 'Address' => [1 \ z& v! t% r( \/ M+ S& X, c
- 'Country' => 'China',6 V# w/ y$ w+ t% ^" u
- 'City' => 'Shen Zhen'
2 N8 P8 D" }$ y& B4 j0 U) j/ f - ],
+ ~- g) o0 N- }9 u - 'E-Mail' => [
+ e4 {; G7 P, k( e' u - '123456@qq.com',
( {/ N* N0 H8 |+ Y, s% c$ g8 n) e - '666666@sina.com',
) v6 t4 p5 v! F) r4 | - '8888888@qq.com',
+ t; H/ I& a- L1 R - '77887788@qq.com'9 A8 i9 I0 z1 k2 j$ C# L
- ]- ~. u5 K w, {/ J- r* x) f( R
- ];
/ \; ]/ [! x! b - $res = $collection->insert($doc);//向集合中插入一个文档3 c" t& d* B/ p
- echo '<pre>';* Z) X2 F F/ O# i7 { B; B) `
- print_r($res);//$res['ok']=1表示插入成功
复制代码二、数据查询 1. 查询单个文档: - //findOne()+ p# G% ]" e0 q* E/ ]9 o; J
- //参数1:搜索条件
& S/ \5 M8 Q. C1 Q: h4 {( {+ x; w - //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非在第二个参数显式加入'_id'=>false。不设置则返回所有字段
1 p: U9 q9 ^& { W4 [' }) k - $mongo = new MongoClient('mongodb://localhost:27017');. P2 W5 W: b2 V5 v; r2 l4 l `" h+ l
- $db = $mongo->mf;3 C+ _4 r/ d+ `+ q
- $collection = $db->friend;
8 G$ e; {( I' [ T8 x9 c - $one = $collection->findOne(['First Name' => 'Jet']);# O% E& x9 K2 P) E. R0 G
- echo '<pre>';4 ?3 m- G5 S- l( k# Z3 b, P
- print_r($one);//返回一个数组,查不到数据则返回NULL
复制代码2. 查询多个文档: - //find()
; d5 _$ ~' P9 L3 i: ]4 q, u - //参数1:搜索条件( ?8 E0 B8 Z9 h u2 N
- //参数2:指定返回字段,array('fieldname' => true, 'fieldname2' => true)。_id字段总会返回,除非显式设置为false不返回。不设置则返回所有字段
+ |6 c% w, u# I5 |: o. H! A - $mongo = new MongoClient('mongodb://localhost:27017');
$ f. Z& [2 P# S9 g0 c) x% ~, U* ? - $db = $mongo->mf;
" y* l! c# A2 q* J* I( u9 U - $collection = $db->friend;6 x% {6 S" \/ \* A0 ^
- $cursor = $collection->find(['Address.Country' => 'China']);//使用点操作符查找数组元素
- {: ?) p) o# n - echo '<pre>';- [# q3 _3 X+ f$ a: @
- while($doc = $cursor->getNext()) {//循环读取每个匹配的文档$ D& S) l# V2 |/ V1 L
- print_r($doc);
2 e3 F8 f3 }1 ~9 ? - }
复制代码使用各种条件操作符定义查询: - //mongodb分别使用$lt(小于)、$lte(下雨等于)、$eq(等于)、$gte(大于等于)、$gt(大于)、$ne(不等于)表示<、<=、=、>=、>、<>,用于整数字段查询7 _% C5 e9 ~, O$ S4 ^( {7 j* z c- G5 N( R
- $mongo = new MongoClient('mongodb://localhost:27017');
H) {% n7 z: f' J - $db = $mongo->mf;6 L% B5 j* J* I) P
- $collection = $db->friend;5 J# R$ Q8 S; x
- $cursor = $collection->find(['Age' => ['$gt' => 30]]);
9 Z, S! Z, D8 f0 f - echo '<pre>';
& s* _: U# s! P1 v! a - while($doc = $cursor->getNext()) {
/ W$ _+ r& b. R1 d! U6 S T7 w - print_r($doc);
# Z, a) H- \" d2 |& S! i }+ a - }
复制代码 //查询某个字段的所有不重复的值) T9 X6 d" \5 N, e# D2 ?
$res = $collection->distinct('Age'); - //$in:匹配多个值中任意一个. ^. x- C% Z) @# V% @
- $cursor = $collection->find(['Address.Country' => ['$in' => ['China', 'USA']]]);3 o4 Z( A" C+ u7 h
- 7 f0 a; R$ U8 d- {1 u4 A
- //$all:匹配多个值中所有值(用于数组字段查询)
6 W9 l, I& u% o- v' k$ B - $cursor = $collection->find(['E-Mail' => ['$all' => ['123456@qq.com', '77887788@qq.com']]]);
' [" u2 N6 S7 L! B9 o! \ - % p" j! `' Z/ c3 J, v) i
- //$or:或查询
( z8 Z% G6 t# N3 a - $cursor = $collection->find(['$or' => [['First Name' => 'Jet'], ['Address.Country' => 'USA']]]);
h" s" V9 _9 Y% Z/ P b -
4 X& G0 ^/ P* { - //$slice:获取数组字段中指定数目的元素,位于find()函数第二个参数中
8 c9 E! w/ {8 @- d( | - $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => 2]]);//只返回前两个email8 b6 S [4 S! e& ]( E/ w1 R' I
- $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => -2]]);//只返回最后两个email
" }4 M; }: Y* n$ w, A8 S - $cursor = $collection->find(['First Name' => 'Jet'], ['E-Mail' => ['$slice' => [1, 2]]]);//忽略第一个,返回接下来两个3 ~( h0 g& q- O1 P! l& s
- 4 y' t0 I& c5 e4 v; [9 H' F) e
- //$exists:根据某个字段是否有设置值进行查询
% Q* _# h$ B0 R1 [ n% z- T# ~ - $cursor = $collection->find(['Hobby' => ['$exists' => false]]);//查找Hobby字段未设置值的文档
: ^8 ^3 {, J& c$ f, `. G -
/ q5 `" t2 @; D+ T0 E, C( ], z - //正则表达式查询
* J0 t# j, D& @, j/ U8 B - $cursor = $collection->find(['First Name' => new MongoRegex('/^Je/i')]);//查找First Name字段以Je开头的文档,忽略大小写差异
复制代码使用MongoCursor类提供的其他函数: - //排序:1升序,-1降序1 d% k5 ^2 A% y% Y# a2 Z
- $cursor->sort(['Age' => 1]);: ]8 X: z: l0 V1 t5 u8 L- b* x
- / [1 L$ \$ U0 m( l2 @: m0 z
- //忽略前n个匹配的文档
/ H, R) B9 t$ f; L( [3 k, h! E - $cursor->skip(1);
5 T" M8 X) j. O -
- h, t: y& ~& B, s7 L - //只返回前n个匹配的文档(limit()与skip()结合使用可实现数据分页功能)
7 @# P5 k& [! s2 B - $cursor->limit(1);
7 v1 f+ q' V6 V: M( m& S - . e d4 s0 k7 X6 E2 K8 c3 N
- //匹配文档的总数7 D) `( u4 e: K
- $cursor->count(); c2 d _' _# z% z' S
- 3 U5 D& t- n4 L X6 T
- //指定查询索引& j( q8 j+ x1 A+ x
- $cursor->hint(['Last Name' => -1]);//若索引不存在则会报错
复制代码聚集查询:对数据进行分组统计 - //聚合查询:对数据进行分组统计* h) N' L, ^' J; s: P
- $mongo = new MongoClient('mongodb://localhost:27017');
* }9 m. C5 |# I) S1 U9 a - $db = $mongo->mf;
1 a. q1 j9 a; D2 g, `4 v1 Z+ G - $collection = $db->friend;
' _* n* L# q. P - $res = $collection->aggregate([. Z) Q0 c, K& X- Q% r Q% a5 |* @9 p
- '$group' => [
$ C0 |4 u E U4 b- @3 c - '_id' => '$Address.Country',//分组字段,注意要加上“$”,这里是根据数组字段某个元素值进行分组
3 M9 {# j% J: d( T- |7 M - 'total' => ['$sum' => 1],//求总和,表示每匹配一个文档总和就加1
; _6 y& e1 }4 S4 f) n) z9 | - 'maxAge' => ['$max' => '$Age'],//分组中Age字段最大值
8 E0 N3 O o: L* M - 'minAge' => ['$min' => '$Age']//分组中Age字段最小值* k( ^# j1 l/ ~) @, K+ }1 w @
- ]6 z X! y4 B$ H6 N( V; ~$ p
- ]);& W) ^/ \2 g) N, }) U
- echo '<pre>';* S; j+ a/ u% S- T9 l6 ]
- print_r($res);//返回一个数组,$ret['result']为数组,存放统计结果
% Y- g; \; R5 \0 C8 `" q! Y8 z -
( Y& o3 O) j% P( A7 H -
7 c3 {% u7 y/ s' i( ` - //存在其它操作的聚合查询:多个操作之间执行先后顺序取决于它们位置的先后顺序
" Y1 |$ b; G, x2 _* M - //聚合查询中的所有操作,包括'$group'在内,都是可选的。
S1 ~& |" z* x) ]* t5 M; g - $mongo = new MongoClient('mongodb://localhost:27017');
+ B! X7 t0 M, z - $db = $mongo->mf;" H5 |) W) O/ n, P% f
- $collection = $db->friend;: c0 o+ F2 N, e& c
- $res = $collection->aggregate([
$ ] L( M! Z9 z5 b7 R* ` - [//过滤条件:只对符合条件的原始文档进行聚合运算,若是放在'$group'之后则是只返回符合条件的结果文档% x# I5 s% q8 J1 j
- '$match' => ['Age' => ['$gt' => 30]]
t, v2 d } V+ J. o! h - ],& b( U. b: ]/ ~: A, F
- [//指定分组字段、统计字段" R+ R& |9 T( m* m" e' V
- '$group' => [
" d' q1 [, x Z* d - '_id' => '$Address.Country',
5 M0 {# M5 r; a. z& S } v- _ - 'totalAge' => ['$sum' => '$Age']//计算各个分组Age字段总和
1 x% [$ O% W' |: K% a# f - ]
0 x& X c7 g% ]* Q4 B3 I - ],. c+ ^; E( W5 H) o, \5 B' b; w2 b
- //以下操作若是放在'$group'之前则在聚合前作用于原始文档,若放在'$group'之后则在聚合后作用于结果文档0 v& d1 _: O# \# j7 `# n
- ['$unwind' => '$E-Mail'],//将包含有某个数组类型字段的文档拆分成多个文档,每个文档的同名字段的值为数组中的一个值。
" [8 g+ i3 }, b7 A' t+ o e0 d - ['$project' => ['myAge' => '$Age', 'First Name' => '$First Name']],//指定返回字段,可以对字段进行重命名,格式:返回字段名 => $原来字段名
9 @, z N" D/ Z3 b: [2 P9 s# Z - ['$skip' => 2],//跳过指定数量的文档
; a; N2 A5 p7 p! c8 ? - ['$limit' => 2],//只返回指定数量的文档8 s3 @) K2 j* C' V5 X$ s1 V: ~
- ['$sort' => ['totalAge' => 1]]//排序
. [2 n& j: b2 }1 O8 N - ]);
6 v; l/ P0 G C- _' d |. I" @ - echo '<pre>';
5 D( a# Z* J" A. d+ A - print_r($res);
复制代码 3 J. X, `. Q1 I; _% Y
三、数据修改 - //update()% B; Z W! _( E" F3 _
- //参数1:更新条件,指定更新的目标对象。' a& P3 S7 R/ r, H" [' J
- //参数2:指定用于更新匹配记录的对象。; K8 `7 }' l4 z6 i
- //参数3:扩展选项组。
4 L4 r, U) d& N - // upsert:若设置为true,当没有匹配文档的时候会创建一个新的文档。$ U A$ e$ W( }$ T. o
- // multiple:默认为false,若设置为true,匹配文档将全部被更新。" s2 P) C+ H) t6 U2 \; n
- // fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。
* H& r, l: x$ o+ C; d y - // w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作" {. M! }3 [ Y& F& s
- // j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
4 f+ Z% o/ a! L7 F! l6 L% E0 I9 W - // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间6 L5 H/ p* P, W& g5 l" N
- // timeout:指定客户端需要等待服务器响应的超时时间(毫秒): x8 |0 I$ H8 ?
- //注意:若不使用任何修改操作符,则匹配文档将直接被整个替换为参数2指定的对象。; n+ l2 A6 [1 G3 g5 G
-
* `# Y7 I. B. c( K6 F% { - //$inc:增加特定键的值,若字段不存在则新建字段并赋值. @. h8 A1 B3 O/ d& e, x
- $mongo = new MongoClient('mongodb://localhost:27017');9 L4 u( `- Y+ Q8 a% N5 G
- $db = $mongo->mf;8 ?6 ]2 j! z5 ?# S
- $collection = $db->friend;
0 J5 f. T$ w' D& N/ m - $res = $collection->update(['First Name' => 'Jet'], ['$inc' => ['Age' => 2]]);
8 d8 R6 L0 t0 x0 A; k - echo '<pre>';
, J4 F. w& Y" S% n8 p# M - print_r($res);//$res['ok']=1表示修改成功,$res['nModified']表示修改的文档数量
6 |. M. k0 M$ I9 x* @8 \ - % C3 p* }# H. a- G
- //$set:重置特定键的值,若字段不存在则新建字段并赋值
) v7 k @0 F0 q. ? - $res = $collection->update(['First Name' => 'Jet'], ['$set' => ['Hobby' => 'pingpong']]);8 ~* c9 g- D/ w$ w6 O% E9 s
- ! Z* j. \( j% P7 R$ p- i* n
- //$unset:删除字段
+ I M% {2 P/ v" i! X7 J - $res = $collection->update(['First Name' => 'Jet'], ['$unset' => ['Hobby' => 1]]);
3 U8 C- @0 B- { -
( t: r% W5 s. ?% R V/ V - //$rename:重命名字段,若字段不存在则不进行任何操作4 B F8 f5 n8 s
- $res = $collection->update(['First Name' => 'Jet'], ['$rename' => ['Hobby' => 'hobby', 'Age' => 'age']]);8 H, X$ ]) E) `7 X5 H! i5 v
- //注意:如果文档中已经使用了指定名称的字段,则该字段将会被删除,然后再进行重命名操作。) e+ l8 w- p: O% b* G" y$ N
-
4 N6 M" T0 ~/ u - //$setOnInsert:设置了upsert为true,并且发生了插入操作的时候,将某个字段设置为特定的
2 ~$ Q" k+ ~& {6 z) y1 v - $res = $collection->update(['First Name' => 'jet'], ['$setOnInsert' => ['lang' => 'English']], ['upsert' => true]);
! X$ i5 Q# R% r$ Z* h8 s1 J4 S -
5 j! b$ t1 l9 _; f f - //$push:向指定字段添加一个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错7 j4 ?* V1 a8 o) o! V, V
- $res = $collection->update(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '123123@qq.com']]);
. |$ R9 A' D+ Z) K, z* q$ K& j -
% d; Y' c, b9 c' t - //$push:向指定字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错/ [4 ?: a* l% M" U3 N4 ^
- $res = $collection->update(['First Name' => 'Jet'], ['$pushAll' => ['E-Mail' => ['666@qq.com', '8888888@qq.com']]]);* y8 P4 c% d- @, H+ Q
-
- i6 l% o5 d+ }# M! q - //使用$push和$each向某个字段添加多个值(作用于数组字段),若字段不存在会先创建字段,若字段值不是数组会报错& N, x/ E/ n3 k- B- {6 x& E
- $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 -
" c0 \7 s& W1 |1 _, S# `1 h0 I - //$addToSet:将数据添加到数组中(只在目标数组没有该数据的时候才将数据添加到数组中)& {1 r! B' o5 O
- $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => '123123@qq.com']]);# ^+ H. ^; G: V, G" k
- $res = $collection->update(['First Name' => 'Jet'], ['$addToSet' => ['E-Mail' => ['$each' => ['123123@qq.com', '666@qq.com']]]]);
/ a$ {# o# b8 w/ F+ n% y$ o - : p9 k. y# }! d
- //$pop:从数组中删除一个元素,-1表示删除第一个元素,1表示删除最后一个元素(其实负数都删除第一个元素,0或正数都删除最后一个元素)
2 h- J E7 V! G0 ]8 n* y - $res = $collection->update(['First Name' => 'Jet'], ['$pop' => ['E-Mail' => 1]]);3 S# I! Y/ c& d O' ?3 m- e2 X# j
- " `4 a' \# f! R6 N8 L
- //$pull:删除数组中所有指定值4 d, B9 Y) Y3 x9 N0 n* m
- $res = $collection->update(['First Name' => 'Jet'], ['$pull' => ['E-Mail' => '123123@qq.com']]);* g/ H* S, ~( ~7 G8 M: |
- # \% {" p: }" u) w- g) n
- //$pullAll:删除数组中多个元素的所有值7 m" W' O6 |9 @3 b; G" j$ x, ]
- $res = $collection->update(['First Name' => 'Jet'], ['$pullAll' => ['E-Mail' => ['123123@qq.com', '666@qq.com']]]);
复制代码- //save()
! O' `. m- H& G$ u - //参数1:希望保存的信息数组
( x" V7 T% d a# s; q5 M! d - //参数2:扩展选项2 V9 N! S3 \+ |
- // fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。' G* |, |/ X3 m i6 O* ^
- // w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作, [2 }9 ?) N& c8 K( E+ t2 o
- // j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。' |* a1 J2 F- B$ U; w
- // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间
3 o/ ]. d. }2 {! s( l! F' s& c/ r - // timeout:指定客户端需要等待服务器响应的超时时间(毫秒)/ v3 I1 L/ F& Q0 l2 f2 x" t4 J9 q
- //注意:若已存在则更新,若不存在则插入;更新时使用参数1指定的信息数组替换整个文档。
7 c. y. g2 x6 ?0 d$ K - //若想更新则应该在参数1中指定_id键的值。7 y) F+ u- v" o- W1 s. O3 P
- $mongo = new MongoClient('mongodb://localhost:27017');
$ U* w, M1 j) F, P- i7 s& _0 u, L6 H$ I4 `; F - $db = $mongo->mf;
- `; @6 Z! [% k' c - $collection = $db->friend;
1 N. h% k+ F K+ s8 A) d& B* | - $doc = [//定义一个文档,即一个数组. {# g( [7 a, f; w
- 'First Name' => 'Jet',
2 U1 R, [ ` d3 N - 'Last Name' => 'Wu',7 y$ k0 @- z( g9 z
- 'Age' => 26,
) N% c" @& W! T - 'Phone' => '110',, g4 L* M! ~. r" Q6 `
- 'Address' => [
, o6 @+ W: q5 K% S3 ?0 g S - 'Country' => 'China',9 R2 d9 V% v' y$ R+ R
- 'City' => 'Shen Zhen'
! J; i. g5 u* B, l - ],
& Y' D4 h0 H- C0 j - 'E-Mail' => [3 T' y1 }, Z% ?
- '123456@qq.com',. V% D& W) U/ j) Q8 y
- '666666@sina.com',0 y' _/ s* C8 ?$ M2 X$ R
- '8888888@qq.com',
/ _8 d$ z4 p( C' s! B' H - '77887788@qq.com'
; S% u9 W" H/ @! W. ^" K0 } - ]- u) K" k* ?- L3 J, g
- ];8 Z2 C( o! E4 X# j3 U
- $res = $collection->save($doc);
8 Y3 s" w' R; q Z2 P7 ] - echo '<pre>';1 u1 F* G$ ]; v4 p: r. |4 P8 h7 ]
- print_r($res);//$res['ok']=1表示操作成功,$res['updatedExisting']=1表示更新,$res['upserted']=1表示插入
; P* A! G1 U9 ?# ?1 V - ! n% I% P2 D% C9 k
复制代码- //findAndModify()9 y9 d) E. Z# w: X, F
- //参数1:指定查询条件7 L* l/ ? i0 }
- //参数2:指定用于更新文档的信息' c3 s) u% I0 }# D8 |, Y/ h4 r
- //参数3:可选,指定希望返回的字段' U6 i* d2 d4 o( K: v
- //参数4:扩展选项
, H6 l# w$ Y: w# h! S8 B - // sort:以特定顺序对匹配文档进行排序+ H+ ]+ K/ g. ?& d
- // remove:若设置为true,第一个匹配文档将被删除1 h, |: L' e% n
- // update:若设置为true,将在被选择的文档上执行更新操作
: p3 `& u5 a- F5 F! K5 Q! W - // new:默认为false,若设置为true则返回更新后的文档,否则返回更新前的文档) f7 f# r3 C( |
- // upsert:若设置为true,没有找到匹配文档的时候将插入一个新的文档
9 T! D, g8 V. I3 a }$ {% g - $mongo = new MongoClient('mongodb://localhost:27017');
) \2 v2 \; I+ }, T - $db = $mongo->mf;9 Z7 R) J# I7 g
- $collection = $db->friend;
3 a% P! @2 J6 H1 x7 P- Y: Y: R - $res = $collection->findAndModify(['First Name' => 'Jet'], ['$push' => ['E-Mail' => '111@qq.com']]);
j' T+ b9 J4 `- h - echo '<pre>';
* s' w1 ~: v5 s* w ]' _- S - print_r($res);
复制代码 四、数据删除 - //remove()3 f& z1 W& ?" Q4 C
- //参数1:查询条件0 @3 X% E; P% M! k1 E
- //参数2:扩展选项
- `& P! T. n( S - // justOne:若设置为true,则最多只有一个匹配的文档将被删除
. d7 `& ?" ]: g9 h - // fsync:若设置为true,w参数将被覆盖为0,数据将在更新结果返回前同步到磁盘。
( n$ S7 b* u! w7 q - // w:默认为1;若设置为0,更新操作将不会得到确认;使用复制集时可设置为n,确保主服务器在将修改复制到n个节点后才确认该更新操作/ ?& v# |' ?" H) a O# r7 q
- // j:默认为false,若设置为true,数据将在更新结果返回之前写入到日志中。
/ q& v- e3 X0 f$ A# i+ `6 {" X9 O - // wtimeout:默认为10000(毫秒),用于指定服务器等待接收确认的时间3 @7 u2 y f d1 `
- // timeout:指定客户端需要等待服务器响应的超时时间(毫秒)
/ g% ?2 p4 `3 Z& ] - $mongo = new MongoClient('mongodb://localhost:27017');9 K5 V1 ~5 b4 k, V5 k! T7 h
- $db = $mongo->mf;
. e! d2 v7 U, p: A" k8 E! s - $collection = $db->friend;5 u% l! w3 O3 ?: c# p! U; y
- $res = $collection->remove(['First Name' => 'jet']);
7 b8 ?2 o, C+ \4 Z1 { - echo '<pre>';( @* R2 D9 C$ b$ P4 U( {& i8 L; j0 y* ~
- 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数据插入: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017'); z1 Y, c/ ~$ ^' T* m! \5 c
- $bulk = new MongoDB\Driver\BulkWrite;' L: b# N0 k$ H! `
- $bulk->insert(['name' => 'JetWu5', 'age' => 26]);
8 o4 g+ h {0 J/ p1 U! P - $bulk->insert(['name' => 'JetWu6', 'age' => 26]);
: b8 B5 w# y; M -
( e" a& U+ c+ l" d( k - $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认
~0 ^# g) A5 ~: U) g- J - $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);; `8 i! a- n4 A; a
- echo '<pre>';" ]: }( D5 T5 m4 L. K
- print_r($res);
复制代码 9 q2 R. X3 b' A, `& n. X( C
数据查询: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');3 d" w- m* x- E; G1 m9 N& K
- $query = new MongoDB\Driver\Query(['age' => 24], ['sort' => ['age' => 1]]); F' [- A$ n* [& m; G/ N a% c% e& [
- $cursor = $manager->executeQuery('wjt.friend', $query);
4 j* @% X# R4 }, F8 c - $ g( T* A( m) @" d/ w
- $data = []; N) C y3 P3 K* R9 o) }; ~! c7 P
- foreach($cursor as $doc) {" C* h3 m2 q6 `/ g! f! s8 O: I" H
- $data[] = $doc;
- F! S- K; Z' {1 P" g! d - }' s" c8 W2 p7 A* P. v' M
- echo '<pre>';& Q2 U" [( y8 p# c" G; Z6 t
- print_r($data);
复制代码 数据修改: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');8 J+ Q0 Y2 _* `; P' p. H) i
- $bulk = new MongoDB\Driver\BulkWrite;
' W5 H6 c& j1 t2 q1 x) H# Q - $bulk->update($ n3 w# }* t3 r$ ?. Z
- ['name' => 'JetWu5'],2 ^) E4 q- U; v, @2 G' N4 e4 n
- ['$set' => ['age' => 30, 'promise' => 'always smile!']]
# M: J5 T' t, x4 ~7 |* K, C" @ - );
( n. R5 T8 c7 V4 t- X2 W - $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认
6 z' ]: m: U0 p- w- V. h - $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);
. }& Y; z; B Z - echo '<pre>';
- x2 e5 Y/ K: z8 m, T/ y - print_r($res);
复制代码 数据删除: - $manager = new MongoDB\Driver\Manager('mongodb://localhost:27017');5 g; a5 m; b$ j/ ]0 f, h& K6 u, F
- $bulk = new MongoDB\Driver\BulkWrite;
$ N; }7 `4 G' n% d* r6 ` - $bulk->delete(['name' => 'JetWu3']);
: x, a8 m/ T% {; U& w' b4 I& L) ` - $bulk->delete(['name' => 'JetWu4']);
8 H M7 r+ v: W5 D9 O - $writeConcern = new MongoDB\Driver\WriteConcern(MongoDB\Driver\WriteConcern::MAJORITY, 1000);//可选,修改确认" f- w$ _+ ~8 E2 \/ Z+ m3 `5 B: X
- $res = $manager->executeBulkWrite('wjt.friend', $bulk, $writeConcern);8 e7 F7 ]$ B; k( r( h8 c" Q2 `! x4 H
- echo '<pre>';1 c8 R6 j( y% `$ D/ {
- 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
|