MongoDB
webman utilizza per impostazione predefinita mongodb/laravel-mongodb come componente mongodb, che è stato estratto da un progetto laravel, e il suo utilizzo è identico a quello di laravel.
Prima di utilizzare jenssegers/mongodb
, è necessario installare l'estensione mongodb per php-cli
.
Attenzione
Questo manuale è per la versione webman v2. Se stai utilizzando la versione webman v1, consulta il manuale della versione v1.
Utilizza il comandophp -m | grep mongodb
per controllare sephp-cli
ha installato l'estensione mongodb. Nota: anche se hai installato l'estensione mongodb inphp-fpm
, non significa che puoi usarla inphp-cli
, poichéphp-cli
ephp-fpm
sono applicazioni diverse, che potrebbero utilizzare configurazioniphp.ini
differenti. Usa il comandophp --ini
per vedere quale file di configurazionephp.ini
stai usando perphp-cli
.
Installazione
composer require -W webman/database mongodb/laravel-mongodb ^4.8
Dopo l'installazione è necessario riavviare (reload non è efficace).
Configurazione
Aggiungi la connessione mongodb
in config/database.php
, simile a quanto segue:
return [
'default' => 'mysql',
'connections' => [
...qui ci sono altre configurazioni omesse...
'mongodb' => [
'driver' => 'mongodb',
'host' => '127.0.0.1',
'port' => 27017,
'database' => 'test',
'username' => null,
'password' => null,
'options' => [
// qui puoi passare ulteriori impostazioni al Mongo Driver Manager
// consulta https://www.php.net/manual/en/mongodb-driver-manager.construct.php sotto "Uri Options" per un elenco completo dei parametri che puoi utilizzare
'appname' => 'homestead'
],
],
],
];
Esempio
<?php
namespace app\controller;
use support\Request;
use support\Db;
class UserController
{
public function db(Request $request)
{
Db::connection('mongodb')->table('test')->insert([1,2,3]);
return json(Db::connection('mongodb')->table('test')->get());
}
}
Esempio di modello
<?php
namespace app\model;
use DateTimeInterface;
use support\MongoModel as Model;
class Test extends Model
{
protected $connection = 'mongodb';
protected $table = 'test';
public $timestamps = true;
/**
* @param DateTimeInterface $date
* @return string
*/
protected function serializeDate(DateTimeInterface $date): string
{
return $date->format('Y-m-d H:i:s');
}
}