PHP
Utilizando MongoDB
Buscar..
Conectarse a MongoDB
Cree una conexión MongoDB, que luego puede consultar:
$manager = new \MongoDB\Driver\Manager('mongodb://localhost:27017');
En el siguiente ejemplo, aprenderá cómo consultar el objeto de conexión.
Esta extensión cierra la conexión automáticamente, no es necesario cerrar manualmente.
Obtener un documento - findOne ()
Ejemplo para buscar solo un usuario con un ID específico, debe hacer:
$options = ['limit' => 1];
$filter = ['_id' => new \MongoDB\BSON\ObjectID('578ff7c3648c940e008b457a')];
$query = new \MongoDB\Driver\Query($filter, $options);
$cursor = $manager->executeQuery('database_name.collection_name', $query);
$cursorArray = $cursor->toArray();
if(isset($cursorArray[0])) {
var_dump($cursorArray[0]);
}
Obtener varios documentos - encontrar ()
Ejemplo para buscar varios usuarios con el nombre "Mike":
$filter = ['name' => 'Mike'];
$query = new \MongoDB\Driver\Query($filter);
$cursor = $manager->executeQuery('database_name.collection_name', $query);
foreach ($cursor as $doc) {
var_dump($doc);
}
Insertar documento
Ejemplo para agregar un documento:
$document = [
'name' => 'John',
'active' => true,
'info' => ['genre' => 'male', 'age' => 30]
];
$bulk = new \MongoDB\Driver\BulkWrite;
$_id1 = $bulk->insert($document);
$result = $manager->executeBulkWrite('database_name.collection_name', $bulk);
Actualizar un documento
Ejemplo para actualizar todos los documentos donde el nombre es igual a "John":
$filter = ['name' => 'John'];
$document = ['name' => 'Mike'];
$bulk = new \MongoDB\Driver\BulkWrite;
$bulk->update(
$filter,
$document,
['multi' => true]
);
$result = $manager->executeBulkWrite('database_name.collection_name', $bulk);
Borrar un documento
Ejemplo para borrar todos los documentos donde el nombre es igual a "Peter":
$bulk = new \MongoDB\Driver\BulkWrite;
$filter = ['name' => 'Peter'];
$bulk->delete($filter);
$result = $manager->executeBulkWrite('database_name.collection_name', $bulk);
Modified text is an extract of the original Stack Overflow Documentation
Licenciado bajo CC BY-SA 3.0
No afiliado a Stack Overflow