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-cli
とphp-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');
}
}