Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
Y
yii2
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
PSDI Army
yii2
Commits
ef12934b
Commit
ef12934b
authored
Mar 04, 2014
by
Paul Klimov
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2613 from mongosoft/mongodb
add findAndModify() method to the Collection class
parents
2ecb79dc
1676d914
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
81 additions
and
1 deletion
+81
-1
Collection.php
extensions/mongodb/Collection.php
+27
-1
CollectionTest.php
tests/unit/extensions/mongodb/CollectionTest.php
+54
-0
No files found.
extensions/mongodb/Collection.php
View file @
ef12934b
...
...
@@ -260,7 +260,7 @@ class Collection extends Object
}
/**
* Returns a
a
single document.
* Returns a single document.
* @param array $condition query condition
* @param array $fields fields to be selected
* @return array|null the single document. Null is returned if the query results in nothing.
...
...
@@ -272,6 +272,32 @@ class Collection extends Object
}
/**
* Updates a document and returns it.
* @param array $condition query condition
* @param array $update update criteria
* @param array $fields fields to be returned
* @param array $options list of options in format: optionName => optionValue.
* @return array|null the original document, or the modified document when $options['new'] is set.
* @throws Exception on failure.
* @see http://www.php.net/manual/en/mongocollection.findandmodify.php
*/
public
function
findAndModify
(
$condition
,
$update
,
$fields
=
[],
$options
=
[])
{
$condition
=
$this
->
buildCondition
(
$condition
);
$token
=
$this
->
composeLogToken
(
'findAndModify'
,
[
$condition
,
$update
,
$fields
,
$options
]);
Yii
::
info
(
$token
,
__METHOD__
);
try
{
Yii
::
beginProfile
(
$token
,
__METHOD__
);
$result
=
$this
->
mongoCollection
->
findAndModify
(
$condition
,
$update
,
$fields
,
$options
);
Yii
::
endProfile
(
$token
,
__METHOD__
);
return
$result
;
}
catch
(
\Exception
$e
)
{
Yii
::
endProfile
(
$token
,
__METHOD__
);
throw
new
Exception
(
$e
->
getMessage
(),
(
int
)
$e
->
getCode
(),
$e
);
}
}
/**
* Inserts new data into collection.
* @param array|object $data data to be inserted.
* @param array $options list of options in format: optionName => optionValue.
...
...
tests/unit/extensions/mongodb/CollectionTest.php
View file @
ef12934b
...
...
@@ -187,6 +187,60 @@ class CollectionTest extends MongoDbTestCase
$this
->
assertNotEmpty
(
$result
[
0
][
'items'
]);
}
public
function
testFindAndModify
()
{
$collection
=
$this
->
getConnection
()
->
getCollection
(
'customer'
);
$rows
=
[
[
'name'
=>
'customer 1'
,
'status'
=>
1
,
'amount'
=>
100
,
],
[
'name'
=>
'customer 2'
,
'status'
=>
1
,
'amount'
=>
200
,
],
];
$collection
->
batchInsert
(
$rows
);
// increment field
$result
=
$collection
->
findAndModify
([
'name'
=>
'customer 1'
],
[
'$inc'
=>
[
'status'
=>
1
]]);
$this
->
assertEquals
(
'customer 1'
,
$result
[
'name'
]);
$this
->
assertEquals
(
1
,
$result
[
'status'
]);
$newResult
=
$collection
->
findOne
([
'name'
=>
'customer 1'
]);
$this
->
assertEquals
(
2
,
$newResult
[
'status'
]);
// $set and return modified document
$result
=
$collection
->
findAndModify
(
[
'name'
=>
'customer 2'
],
[
'$set'
=>
[
'status'
=>
2
]],
[],
[
'new'
=>
true
]
);
$this
->
assertEquals
(
'customer 2'
,
$result
[
'name'
]);
$this
->
assertEquals
(
2
,
$result
[
'status'
]);
// Full update document
$data
=
[
'name'
=>
'customer 3'
,
'city'
=>
'Minsk'
];
$result
=
$collection
->
findAndModify
(
[
'name'
=>
'customer 2'
],
$data
,
[],
[
'new'
=>
true
]
);
$this
->
assertEquals
(
'customer 3'
,
$result
[
'name'
]);
$this
->
assertEquals
(
'Minsk'
,
$result
[
'city'
]);
$this
->
assertTrue
(
!
isset
(
$result
[
'status'
]));
// Test exceptions
$this
->
setExpectedException
(
'\yii\mongodb\Exception'
);
$collection
->
findAndModify
([
'name'
=>
'customer 1'
],
[
'$wrongOperator'
=>
[
'status'
=>
1
]]);
}
/**
* @depends testBatchInsert
*/
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment