Hướng dẫn laravel mongodb hasmany - laravel mongodb hasmany
Mở đầuHello 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 và sử dụngĐể 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
B2:
B3:
B4: Cài đặt MongoDB
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:
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: 4. 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:
Và bây giờ mọi thứ đã giống như Eloquent tương tác với MySQL rồi nhé:
Ngoài ra MongoDB còn có các toán tử đặc biệt:
RelationsHỗ trợ các loại relationship sau:
Các quan hệ 5, 6, 7 về cơ bản cách lưu dữ liệu giống như với MySQL nhưng với 8 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ề. Ngoài các quan hệ đó ta có thêm 2 quan hệ đặc biệt nữa thể hiện đặc tính của MongoDB đó là 9 và 0. 2 quan hệ này khá giống với 5 và 6 tuy nhiên điểm khác biệt đó là Embed Model này sẽ nằm trong object của Model cha. Ví dụ User có nhiều tài khoản social network thì về mặt dữ liệu sẽ là
MySQL RelationsNgoài ra nếu trong dự án của bạn sử dụng cả mongodb và mysql thì package này vẫn hỗ trợ 1 trait để có thể hoạt động với các relations giống như mặc định của Laravel đó là 3. Cách sử dụng như sau: User model sử dụng mysql để lưu trữ ta khai báo như sau:
Còn với Message model dùng mongodb để lưu trữ: 0QueuesChính sửa file config/queue.php 1Để handle failed jobs ta sửa config/queue.php: 2Thêm service provider: 4Laravel PassportNgoài ra trong quá trình tìm hiểu và làm việc với MongoDB thì khi mình thử với Laravel Passport lại không hỗ trợ MongoDB. Vì vậy ta lại cần thêm 1 package để có thể custom lại passport để sử dụng cho MongoDB. Đó là Laravel MongoDB Passport. Nôm na thì tác giả đã viết lại các model ẩn dùng cho Laravel Passport mặc định hỗ trợ cho MongoDB. Cài đặt bằng composer: 5 Về cách sử dụng thì hoàn toàn tương tự Laravel Passport. Ta chỉ cần sửa đổi một chút class User: 3Kết luậnNhư vậy mình vừa chia sẻ xong cách để chúng ta có thể sử dụng NoSQL trong Laravel mà cụ thể là MongoDB. Nếu dự án của bạn cần chuyển sang một cơ sở dữ liệu NoSQL hoặc kết hợp vào với MySQL thông thường thì hãy thử MongoDB nhé. Cảm ơn các bạn đã theo dõi bài viết. |