12/08/2018, 18:07

Laravel with MongoDB

Hello anh em, đến hẹn lại lên hôm nay mình xin chia sẻ với mọi người về chủ đề Laravel kết hợp với MongoDB mà thông thường ta hay kết hợp Laravel với MySQL. Và mặc định thì Laravel chỉ hỗ trợ các cơ sở dữ liệu có cấu trúc như: MySQL, PostgreSQL, SQLite, SQL Server. Tuy nhiên theo thời thế thì ...

Hello anh em, đến hẹn lại lên hôm nay mình xin chia sẻ với mọi người về chủ đề Laravel kết hợp với MongoDB mà thông thường ta hay kết hợp Laravel với MySQL. Và mặc định thì Laravel chỉ hỗ trợ các cơ sở dữ liệu có cấu trúc như: MySQL, PostgreSQL, SQLite, SQL Server. Tuy nhiên theo thời thế thì NoSQL ngày càng phát triển mạnh mẽ và được tin dùng bởi nó linh động và có tốc độ cao mà điển hình là MongoDB. Trong phạm vi bài viết này mình chỉ xin đề cập đến MongoDB thay cho cơ sở dữ liệu không có cấu trúc NoSQL. Để tận dụng được những điểm tốt của NoSQL bây giờ ta sẽ tìm cách để có thể sử dụng MongoDB trong Laravel để mang lại hiệu quả tốt nhất. Bắt đầu thôi...

Để cài đặt MongoDB ta chỉ cần vài bước cơ bản như sau: ( ở đây mình cài trên Ubuntu 16.04, trên các hệ điều hành khác các bạn có thể tham khảo ở trang chủ của nó)

B1: Thêm package

sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5

B2:

echo "deb [ arch=amd64,arm64 ] https://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/3.6 multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.6.list

B3:

sudo apt-get update

B4: Cài đặt MongoDB

sudo apt-get install -y mongodb-org

Sau khi cài xong thì ta đã có mongodb trong máy rồi, việc tiếp theo là ta sẽ cài thêm 1 công cụ để tiện quản lý cơ sở dữ liệu. Nó giống như MySQL Workbench thì ở đây ta sẽ sử dụng MongoDB Compass. Việc cài đặt nó khá đơn giản nên các bạn có thể cài theo hướng dẫn này nhé.

Như vậy là ta đã có MongoDB chạy trong máy rồi. Nhưng vẫn chưa đủ, ta phải cài đặt thêm driver để PHP có thể kết nối và thao tác với MongoDB. Việc cài đặt driver này diễn ra như sau:

$ git clone https://github.com/mongodb/mongo-php-driver.git
$ cd mongo-php-driver
$ git submodule update --init
$ phpize
$ ./configure
$ make all
$ sudo make install

Và cuối cùng ta cần làm đó là cài đặt package hỗ trợ Laravel kết nối và thao tác với MongoDB giống như Eloquent mặc định của Laravel. Package đó là jenssegers/mongodb. Cài đặt đơn giản qua composer: composer require jenssegers/mongodb. Mọi thứ đã sẵn sàng, giờ ta có thể sử dụng ngay: Bây giờ ở model ta sẽ extends class Model Eloquent của mongodb:

use JenssegersMongodbEloquentModel as Eloquent;

class User extends Eloquent {}

Và bây giờ mọi thứ đã giống như Eloquent tương tác với MySQL rồi nhé:

$users = User::all();
$user = User::find('517c43667db388101e00000f');
$users = User::where('votes', '>', 100)->take(10)->get();
$users = User::where('votes', '>', 100)->orWhere('name', 'John')->get();
$users = User::whereIn('age', [16, 18, 20])->get();
// OrderBy
$users = User::orderBy('name', 'desc')->get();
// Offset & Limit
$users = User::skip(10)->take(5)->get();
// Distinct
$users = User::distinct()->get(['name']);
// Advanced Wheres
$users = User::where('name', '=', 'John')->orWhere(function($query)
    {
        $query->where('votes', '>', 100)
              ->where('title', '<>', 'Admin');
    })
    ->get();
// Group By
$users = Users::groupBy('title')->get(['title', 'name']);
// Like
$user = Comment::where('body', 'like', '%spam%')->get();

// Hỗ trợ luôn soft delete
use JenssegersMongodbEloquentSoftDeletes;

class User extends Eloquent {

    use SoftDeletes;

    protected $dates = ['deleted_at'];

}
// ...

Ngoài ra MongoDB còn có các toán tử đặc biệt:

// Tìm các document có trường được chỉ định
User::where('age', 'exists', true)->get();
// Tìm kiếm theo mảng 
User::where('roles', 'all', ['moderator', 'author'])->get();
// Sử dụng regex
User::where('name', 'regex', new MongoDBBSONRegex("/.*doe/i"))->get();
// Tìm theo loại dữ liệu https://docs.mongodb.com/manual/reference/operator/query/type/#op._S_type
User::where('age', 'type', 2)->get();
// Truy vấn theo khoảng cách và kinh độ vĩ độ
$users = User::where('location', 'near', [
	'$geometry' => [
        'type' => 'Point',
	    'coordinates' => [
	        -0.1367563,
            51.5100913,
        ],
    ],
    '$maxDistance' => 50,
]);
// GeoWithin
$users = User::where('location', 'geoWithin', [
	'$geometry' => [
        'type' => 'Polygon',
	    'coordinates' => [[
            [
                -0.1450383,
                51.5069158,
            ],       
            [
                -0.1367563,
                51.5100913,
            ],       
            [
                -0.1270247,
                51.5013233,
            ],  
            [
                -0.1450383,
                51.5069158,
            ],
        ]],
    ],
]);
// GeoIntersects
$locations = Location::where('location', 'geoIntersects', [
    '$geometry' => [
        'type' => 'LineString',
        'coordinates' => [
            [
                -0.144044,
                51.515215,
            ],
            [
                -0.129545,
                51.507864,
            ],
        ],
    ],
]);

Relations

Hỗ trợ các loại relationship sau:

  • hasOne
  • hasMany
  • belongsTo
  • belongsToMany
  • embedsOne
  • embedsMany

Các quan hệ hasOne, hasMany, belongsTo về cơ bản cách lưu dữ liệu giống như với MySQL nhưng với belongsToMany thì lại là một điểm khác biệt. Ở MySQL ta dùng thêm 1 bảng trung gian để lưu quan hệ gọi là pivot table nhưng với MongoDB thì ta không cần làm như vậy mà ta chỉ cần lưu id của bảng quan hệ vào 1 trường dạng mảng của bảng còn lại. Ví dụ như User belongsToMany với Role thì ta trong bảng users ta có trường role_ids lưu các id của role mà user đó nắm giữ đồng thời trong bảng roles ta lại có trường user_ids là mảng chứa các user id mà role đó thuộc về.             </div>
            
            <div class=

0