MongoDB

webman 預設使用 mongodb/laravel-mongodb 作為 mongodb 組件,它是從 laravel 專案中抽離出來的,用法與 laravel 相同。

使用 jenssegers/mongodb 之前必須先給 php-cli 安裝 mongodb 擴展。

注意
當前手冊為 webman v2 版本,如果您使用的是 webman v1 版本,請查看 v1 版本手冊
使用命令 php -m | grep mongodb 查看 php-cli 是否裝了 mongodb 擴展。注意:即使你在 php-fpm 安裝了 mongodb 擴展,不代表你在 php-cli 可以使用它,因為 php-cliphp-fpm 是不同的應用程序,可能使用的是不同的 php.ini 配置。使用命令 php --ini 來查看你的 php-cli 使用的是哪個 php.ini 配置文件。

安裝

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

安裝後需要 restart 重啟(reload 無效)

配置

config/database.php 裡增加 mongodb 連接,類似如下:

return [

    'default' => 'mysql',

    'connections' => [

         ...這裡省略了其它配置...

        'mongodb' => [
            'driver'   => 'mongodb',
            'host'     => '127.0.0.1',
            'port'     =>  27017,
            'database' => 'test',
            'username' => null,
            'password' => null,
            'options' => [
                // 在這裡您可以傳遞更多設置給 Mongo Driver Manager
                // 請參見 https://www.php.net/manual/en/mongodb-driver-manager.construct.php 下的 "Uri Options" 獲取完整參數列表

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

示例

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

模型示例

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

更多內容請訪問

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