MongoDB

Webman verwendet standardmäßig mongodb/laravel-mongodb als MongoDB-Komponente, die aus einem Laravel-Projekt extrahiert wurde und deren Verwendung der von Laravel entspricht.

Bevor Sie jenssegers/mongodb verwenden können, müssen Sie das MongoDB-Erweiterung für php-cli installieren.

Achtung
Dieses Handbuch ist für die Webman v2-Version. Wenn Sie die Webman v1-Version verwenden, konsultieren Sie bitte das Handbuch der v1-Version.
Verwenden Sie den Befehl php -m | grep mongodb, um zu überprüfen, ob die MongoDB-Erweiterung in php-cli installiert ist. Hinweis: Selbst wenn Sie die MongoDB-Erweiterung in php-fpm installiert haben, bedeutet dies nicht, dass Sie sie in php-cli verwenden können, da php-cli und php-fpm verschiedene Anwendungen sind, die möglicherweise unterschiedliche php.ini-Konfigurationen verwenden. Verwenden Sie den Befehl php --ini, um zu überprüfen, welche php.ini-Konfigurationsdatei Ihr php-cli verwendet.

Installation

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

Nach der Installation müssen Sie den Dienst neu starten (Reload ist nicht wirksam).

Konfiguration

Fügen Sie eine mongodb-Verbindung in config/database.php hinzu, ähnlich wie folgt:

return [

    'default' => 'mysql',

    'connections' => [

         ...hier sind andere Konfigurationen ausgelassen...

        'mongodb' => [
            'driver'   => 'mongodb',
            'host'     => '127.0.0.1',
            'port'     =>  27017,
            'database' => 'test',
            'username' => null,
            'password' => null,
            'options' => [
                // hier können Sie weitere Einstellungen an den Mongo Driver Manager übergeben
                // siehe https://www.php.net/manual/en/mongodb-driver-manager.construct.php unter "Uri Options" für eine vollständige Liste der Parameter, die Sie verwenden können

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

Beispiel

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

Modellbeispiel

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

Weitere Inhalte finden Sie unter

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