跳到主要內容

MongoDB

簡介

MongoDB 是最受歡迎的 NoSQL 文件導向資料庫之一,因其高寫入負載(適用於分析或 IoT)和高可用性(易於設定具有自動故障轉移的副本集)而被使用。它還可以輕鬆地對資料庫進行分片以實現水平擴展,並具有強大的查詢語言,用於執行聚合、文字搜尋或地理空間查詢。

與 SQL 資料庫將資料儲存在行或列的表格中不同,MongoDB 資料庫中的每筆記錄都是以 BSON 描述的文件,BSON 是資料的二進制表示形式。然後,應用程式可以 JSON 格式檢索此資訊。它支援各種資料類型,包括文件、陣列、嵌入式文件和二進制資料。

在使用 Laravel 的 MongoDB 之前,我們建議透過 Composer 安裝和使用 mongodb/laravel-mongodb 套件。 laravel-mongodb 套件由 MongoDB 官方維護,雖然 PHP 透過 MongoDB 驅動程式原生支援 MongoDB,但 Laravel MongoDB 套件提供了與 Eloquent 和其他 Laravel 功能更豐富的整合

1composer require mongodb/laravel-mongodb

安裝

MongoDB 驅動程式

若要連線到 MongoDB 資料庫,需要 mongodb PHP 擴充套件。如果您在本機使用 Laravel Herd 開發或透過 php.new 安裝 PHP,則您的系統上已安裝此擴充套件。但是,如果您需要手動安裝擴充套件,您可以透過 PECL 進行安裝

1pecl install mongodb

有關安裝 MongoDB PHP 擴充套件的更多資訊,請查看 MongoDB PHP 擴充套件安裝說明

啟動 MongoDB 伺服器

MongoDB Community Server 可用於在本機執行 MongoDB,並可在 Windows、macOS、Linux 或 Docker 容器上安裝。若要了解如何安裝 MongoDB,請參閱 官方 MongoDB Community 安裝指南

MongoDB 伺服器的連線字串可以在您的 .env 檔案中設定

1MONGODB_URI="mongodb://127.0.0.1:27017"
2MONGODB_DATABASE="laravel_app"

對於在雲端託管 MongoDB,請考慮使用 MongoDB Atlas。若要從您的應用程式在本機存取 MongoDB Atlas 叢集,您需要將您自己的 IP 位址新增到專案 IP 存取清單中的叢集網路設定中

MongoDB Atlas 的連線字串也可以在您的 .env 檔案中設定

1MONGODB_URI="mongodb+srv://<username>:<password>@<cluster>.mongodb.net/<dbname>?retryWrites=true&w=majority"
2MONGODB_DATABASE="laravel_app"

安裝 Laravel MongoDB 套件

最後,使用 Composer 安裝 Laravel MongoDB 套件

1composer require mongodb/laravel-mongodb

如果未安裝 mongodb PHP 擴充套件,則此套件的安裝將會失敗。PHP 設定在 CLI 和 Web 伺服器之間可能有所不同,因此請確保在兩種設定中都啟用該擴充套件。

設定

您可以透過應用程式的 config/database.php 設定檔設定您的 MongoDB 連線。在此檔案中,新增一個使用 mongodb 驅動程式的 mongodb 連線

1'connections' => [
2 'mongodb' => [
3 'driver' => 'mongodb',
4 'dsn' => env('MONGODB_URI', 'mongodb://127.0.0.1:27017'),
5 'database' => env('MONGODB_DATABASE', 'laravel_app'),
6 ],
7],

功能

完成設定後,您可以在您的應用程式中使用 mongodb 套件和資料庫連線,以利用各種強大的功能

若要繼續學習如何使用 MongoDB 和 Laravel,請參閱 MongoDB 的快速入門指南