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
8ede55a0
Commit
8ede55a0
authored
Jan 14, 2014
by
Paul Klimov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Documentation for "mongodb" extension improved.
parent
32d82f59
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
128 additions
and
9 deletions
+128
-9
Collection.php
extensions/mongodb/Collection.php
+2
-2
README.md
extensions/mongodb/README.md
+126
-7
No files found.
extensions/mongodb/Collection.php
View file @
8ede55a0
...
...
@@ -21,7 +21,7 @@ use yii\helpers\Json;
* For example:
*
* ~~~
* $collection = Yii::$app->mongo->getCollection('customer');
* $collection = Yii::$app->mongo
db
->getCollection('customer');
* $collection->insert(['name' => 'John Smith', 'status' => 1]);
* ~~~
*
...
...
@@ -55,7 +55,7 @@ use yii\helpers\Json;
* ~~~
*
* Note: condition values for the key '_id' will be automatically cast to [[\MongoId]] instance,
* even if they are plain strings. However if you have other columns, containing [[\MongoId]], you
* even if they are plain strings. However
,
if you have other columns, containing [[\MongoId]], you
* should take care of possible typecast on your own.
*
* @property string $fullName Full name of this collection, including database name. This property is
...
...
extensions/mongodb/README.md
View file @
8ede55a0
...
...
@@ -26,8 +26,8 @@ or add
to the require section of your composer.json.
Usage & Documentation
-------------
--------
General Usage
-------------
To use this extension, simply add the following code in your application configuration:
...
...
@@ -43,6 +43,87 @@ return [
];
```
Using the connection instance you may access databases and collections.
Most of the MongoDB commands are accessible via
[
[\yii\mongodb\Collection
]
] instance:
```
php
$collection
=
Yii
::
$app
->
mongodb
->
getCollection
(
'customer'
);
$collection
->
insert
([
'name'
=>
'John Smith'
,
'status'
=>
1
]);
```
To perform "find" queries, you should use
[
[\yii\mongodb\Query
]
]:
```
php
use
yii\mongodb\Query
;
$query
=
new
Query
;
// compose the query
$query
->
select
([
'name'
,
'status'
])
->
from
(
'customer'
)
->
limit
(
10
);
// execute the query
$rows
=
$query
->
all
();
```
This extension supports logging and profiling, however log messages does not contain
actual text of the performed queries, they contains only a “close approximation” of it
composed on the values which can be extracted from PHP Mongo extension classes.
If you need to see actual query text, you should use specific tools for that.
Notes about MongoId
-------------------
Remember: MongoDB document id ("_id" field) is not scalar, but an instance of
[
[\MongoId
]
] class.
To get actual Mongo ID string your should typecast
[
[\MongoId
]
] instance to string:
```
php
$query
=
new
Query
;
$row
=
$query
->
from
(
'customer'
)
->
one
();
var_dump
(
$row
[
'_id'
]);
// outputs: "object(MongoId)"
var_dump
((
string
)
$row
[
'_id'
]);
// outputs "string 'acdfgdacdhcbdafa'"
```
Although this fact is very useful sometimes, it often produces some problems.
You may face them in URL composition or attempt of saving "_id" to other storage.
In these cases, ensure you have converted
[
[\MongoId
]
] into the string:
```
php
/** @var yii\web\View $this */
echo
$this
->
createUrl
(
'item/update'
,
[
'id'
=>
(
string
)
$row
[
'_id'
]]);
```
While building condition, values for the key '_id' will be automatically cast to
[
[\MongoId
]
] instance,
even if they are plain strings. So it is not necessary for you to perform back cast of string '_id'
representation:
```
php
use
yii\web\Controller
;
use
yii\mongodb\Query
;
class
ItemController
extends
Controller
{
/**
* @param string $id MongoId string (not object)
*/
public
function
actionUpdate
(
$id
)
{
$query
=
new
Query
;
$row
=
$query
->
from
(
'item'
)
where
([
'_id'
=>
$id
])
// implicit typecast to [[\MongoId]]
->
one
();
...
}
}
```
However, if you have other columns, containing
[
[\MongoId
]
], you
should take care of possible typecast on your own.
Using the MongoDB ActiveRecord
------------------------------
This extension provides ActiveRecord solution similar ot the
[
[\yii\db\ActiveRecord
]
].
To declare an ActiveRecord class you need to extend
[
[\yii\mongodb\ActiveRecord
]
] and
implement the
`collectionName`
and 'attributes' methods:
...
...
@@ -102,10 +183,48 @@ $provider = new ActiveDataProvider([
$models
=
$provider
->
getModels
();
```
Using GridFS
------------
This extension supports
[
MongoGridFS
](
http://docs.mongodb.org/manual/core/gridfs/
)
via
classes under namespace "
\y
ii
\m
ongodb
\f
ile".
There you will find specific Collection, Query and ActiveRecord classes.
This extension supports logging and profiling, however log messages does not contain
actual text of the performed queries, they contains only a “close approximation” of it
composed on the values which can be extracted from PHP Mongo extension classes.
If you need to see actual query text, you should use specific tools for that.
\ No newline at end of file
Using the Cache component
-------------------------
To use the
`Cache`
component, in addition to configuring the connection as described above,
you also have to configure the
`cache`
component to be
`yii\mongodb\Cache`
:
```
php
return
[
//....
'components'
=>
[
// ...
'cache'
=>
[
'class'
=>
'yii\mongodb\Cache'
,
],
]
];
```
Using the Session component
---------------------------
To use the
`Session`
component, in addition to configuring the connection as described above,
you also have to configure the
`session`
component to be
`yii\mongodb\Session`
:
```
php
return
[
//....
'components'
=>
[
// ...
'session'
=>
[
'class'
=>
'yii\mongodb\Session'
,
],
]
];
```
\ No newline at end of file
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