MongoDB

Webman utilise par défaut mongodb/laravel-mongodb comme composant mongodb, qui a été extrait d'un projet laravel, et la façon de l'utiliser est la même que dans laravel.

Avant d'utiliser jenssegers/mongodb, vous devez d'abord installer l'extension mongodb pour php-cli.

Attention
Ce manuel concerne la version v2 de Webman, si vous utilisez la version v1 de Webman, veuillez consulter le manuel de la version v1.
Utilisez la commande php -m | grep mongodb pour vérifier si l'extension mongodb est installée pour php-cli. Attention : même si vous avez installé l'extension mongodb dans php-fpm, cela ne signifie pas que vous pouvez l'utiliser dans php-cli, car php-cli et php-fpm sont des applications différentes qui peuvent utiliser des fichiers de configuration php.ini différents. Utilisez la commande php --ini pour voir quel fichier de configuration php.ini est utilisé par votre php-cli.

Installation

composer require -W webman/database mongodb/laravel-mongodb ^4.8

Après l'installation, il est nécessaire de redémarrer (reload est inefficace).

Configuration

Ajoutez la connexion mongodb dans config/database.php, similaire à ce qui suit :

return [

    'default' => 'mysql',

    'connections' => [

         ...d'autres configurations sont omises ici...

        'mongodb' => [
            'driver'   => 'mongodb',
            'host'     => '127.0.0.1',
            'port'     =>  27017,
            'database' => 'test',
            'username' => null,
            'password' => null,
            'options' => [
                // ici vous pouvez passer plus de paramètres au gestionnaire de drivers Mongo
                // voir https://www.php.net/manual/en/mongodb-driver-manager.construct.php sous "Uri Options" pour une liste complète des paramètres que vous pouvez utiliser

                'appname' => 'homestead'
            ],
        ],
    ],
];

Exemple

<?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());
    }
}

Exemple de modèle

<?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');
    }
}

Pour plus de contenu, veuillez visiter

https://github.com/mongodb/laravel-mongodb