1. Go to this page and download the library: Download doctrine/couchdb library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
doctrine / couchdb example snippets
$client = \Doctrine\CouchDB\CouchDBClient::create(array('dbname' => 'doctrine_example'));
// Create a database.
$client->createDatabase($client->getDatabase());
// Create a new document.
list($id, $rev) = $client->postDocument(array('foo' => 'bar'));
// Update a existing document. This will increment the revision.
list($id, $rev) = $client->putDocument(array('foo' => 'baz'), $id, $rev);
// Fetch single document by id.
$doc = $client->findDocument($id);
// Fetch multiple documents at once.
$docs = $client->findDocuments(array($id));
// Return all documents from database (_all_docs? '$eq'=> 'Under the Dome',
],
'genres'=> [
'$in'=> ['Drama','Comedy'],
],
],
])->sort([['_id'=>'desc']])->limit(1)->skip(1)->use_index(['_design/doc','index']);
$docs = $client->find($query);
class ArticlesDesignDocument implements \Doctrine\CouchDB\View\DesignDocument
{
public function getData()
{
return array(
'language' => 'javascript',
'views' => array(
'by_author' => array(
'map' => 'function(doc) {
if(\'article\' == doc.type) {
emit(doc.author, doc._id);
}
}',
'reduce' => '_count'
),
),
);
}
}
$client->createDesignDocument('articles', new ArticlesDesignDocument());
// Fill database with some data.
foreach (array('Alice', 'Bob', 'Bob') as $author) {
$client->postDocument(array(
'type' => 'article',
'author' => $author,
'content' => 'Lorem ipsum'
));
}
// Query all articles.
$query = $client->createViewQuery('articles', 'by_author');
$query->setReduce(false);
$query->setIncludeDocs(true);
$result = $query->execute();
foreach ($result as $row) {
$doc = $row['doc'];
echo 'Article by ', $doc['author'], ': ', $doc['content'], "\n";
}
// Article by Alice: Lorem ipsum
// Article by Bob: Lorem ipsum
// Article by Bob: Lorem ipsum
// Query all articles written by bob.
$query = $client->createViewQuery('articles', 'by_author');
$query->setKey('Bob');
// ...
// Query the _count of articles each author has written.
$query = $client->createViewQuery('articles', 'by_author');
$query->setReduce(true);
$query->setGroupLevel(1); // group_level=1 means grouping by author.
$result = $query->execute();
foreach ($result as $row) {
echo 'Author ', $row['key'], ' has written ', $row['value'], ' articles', "\n";
}
// Author Alice has written 1 articles
// Author Bob has written 2 articles
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.