MongoDB
webman mặc định sử dụng mongodb/laravel-mongodb làm thành phần mongodb, nó được tách ra từ dự án laravel, cách sử dụng tương tự như laravel.
Trước khi sử dụng jenssegers/mongodb
, bạn phải cài đặt mở rộng mongodb cho php-cli
.
Lưu ý
Tài liệu hiện tại cho phiên bản webman v2, nếu bạn đang sử dụng phiên bản webman v1, vui lòng xem tài liệu phiên bản v1
Sử dụng lệnhphp -m | grep mongodb
để kiểm tra xemphp-cli
đã cài đặt mở rộng mongodb hay chưa. Lưu ý: ngay cả khi bạn đã cài đặt mở rộng mongodb trongphp-fpm
, không có nghĩa là bạn có thể sử dụng nó trongphp-cli
, vìphp-cli
vàphp-fpm
là hai ứng dụng khác nhau, có thể sử dụng các tệp cấu hìnhphp.ini
khác nhau. Sử dụng lệnhphp --ini
để xem tệp cấu hìnhphp.ini
màphp-cli
đang sử dụng.
Cài đặt
composer require -W webman/database mongodb/laravel-mongodb ^4.8
Sau khi cài đặt, cần khởi động lại (restart) thay vì tải lại (reload).
Cấu hình
Thêm kết nối mongodb
vào config/database.php
, tương tự như sau:
return [
'default' => 'mysql',
'connections' => [
...đoạn cấu hình khác đã bị bỏ qua...
'mongodb' => [
'driver' => 'mongodb',
'host' => '127.0.0.1',
'port' => 27017,
'database' => 'test',
'username' => null,
'password' => null,
'options' => [
// ở đây bạn có thể truyền thêm các cài đặt cho Mongo Driver Manager
// xem https://www.php.net/manual/en/mongodb-driver-manager.construct.php dưới "Uri Options" để có danh sách các tham số hoàn chỉnh mà bạn có thể sử dụng
'appname' => 'homestead'
],
],
],
];
Ví dụ
<?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());
}
}
Ví dụ về mô hình
<?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');
}
}