您好,登錄后才能下訂單哦!
這篇文章給大家介紹MongoDB怎么在Laravel中使用,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
MongoDB實用場景
產品用戶訪問日志,點擊埋點統計信息
業務系統環境參數配置信息
業務系統運行時日志,如laravel.log,nginx.log
使用Homebrew在macoOS安裝MongoDB PHP Driver
在macOS中,MongoDB 擴展已經從Homebrew倉庫中移除,需要通過pecl安裝此擴展。
$ sudo pecl install mongodb -v ... Build process completed successfully Installing '/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so' install ok: channel://pecl.php.net/mongodb-1.5.4 Extension mongodb enabled in php.ini
在項目中,使用phpinfo() 查詢PHP擴展安裝位置。
... Configuration File (php.ini) Path /usr/local/etc/php/7.2 Loaded Configuration File /usr/local/etc/php/7.2/php.ini Scan this dir for additional .ini files /usr/local/etc/php/7.2/conf.d Additional .ini files parsed /usr/local/etc/php/7.2/conf.d/ext-opcache.ini, /usr/local/etc/php/7.2/conf.d/php-memory-limits.ini ....
按照ext-opcache.ini配置,創建一個ext-mongodb.ini文件
touch /usr/local/etc/php/7.2/conf.d/ext-mongodb.ini
將mongodb.so擴展寫入該文件
[mongodb] extension=/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so
同時在php.ini中移除mongodb.so擴展
extension="mongodb.so" // remove extension="php_mongodb.so" // remove
重啟一下PHP
sudo brew service restart --all
查看是否安裝成功
php -m|grep mongodb
在Laravel中使用MongoDB
使用Composer創建一個Laravel項目
composer create-project --prefer-dist laravel/laravel laravel-mongodb-exploer -vvv
成功后,再安裝Laravel-MongoDB擴展
composer require jenssegers/mongodb -vvv
按照擴展文檔說明,我們添加一個MongoDB數據庫連接
//database.php ... 'mongodb' => [ 'driver' => 'mongodb', 'host' => env('MONGODB_HOST', 'localhost'), 'port' => env('MONGODB_PORT', 27017), 'database' => env('MONGODB_DATABASE'), 'username' => env('MONGODB_USERNAME'), 'password' => env('MONGODB_PASSWORD'), 'options' => [ 'database' => 'admin' // sets the authentication database required by mongo 3 ] ], ... //.env ... MONGODB_HOST=127.0.0.1 MONGODB_PORT=27017 MONGODB_DATABASE=viewers ...
命令行創建MongoDB數據庫
macOS中,在命令行執行mongo開啟MongoDB Shell
./mongo
使用show dbs查看已有數據庫
show dbs; admin 0.000GB config 0.000GB local 0.000GB viewers 0.000GB
如果沒有發現viewers,則創建該數據庫。注意只有viewers中存在collection時, 上面結果才會顯示viewers
use viewers;
使用數據庫后,需要創建colleciton
db.ad_clicks.insert({"ip":"201.35.63.14", "ad_index": 3, "created_at": "2019-06-10 11:34:12"})
使用find查詢記錄
> db.ad_clicks.find() { "_id" : ObjectId("5cf71b34e14620598643d23b"), "ip" : "201.34.46.3", "ad_index" : "2", "created_at" : "2019-06-05 11:34:53" } { "_id" : ObjectId("5cf71d3de14620598643d23d"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" } { "_id" : ObjectId("5cf71d3ee14620598643d23e"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" } { "_id" : ObjectId("5cf71d44e14620598643d23f"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" } { "_id" : ObjectId("5cf71d45e14620598643d240"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 12:34:12" } { "_id" : ObjectId("5cfe28823316506991c41786"), "ip" : "201.35.63.14", "ad_index" : 3, "created_at" : "2019-06-10 11:34:12" }
在Laravel DB中查詢MongoDB
使用了Laravel-MongoDB擴展,可以基于Eloquent與Query Builder操作MySQL一樣的數據php artisan thinker
查詢ad_clicks集合所有記錄
DB::connection('mongodb')->table('ad_clicks')->get()
查詢單個記錄
DB::connection('mongodb')->collection('ad_clicks')->find('5cf71b34e14620598643d23b')
修改某個記錄
DB::connection('mongodb')->collection('ad_clicks')->where('_id', '5cf71b34e14620598643d23b')->update(['ad_index'=>2]);
在Laravel ORM中查詢MongoDB
在項目中,創建一個Model
php artisan make:model Models/AdClick
修改繼承父類和數據庫連接,AdClick.php
... use Jenssegers\Mongodb\Eloquent\Model; class AdClick extends Model { protected $connection = 'mongodb'; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = []; /** * The attributes that aren't mass assignable. * * @var array */ protected $guarded = []; }
繼續在Thinker中,插入數據
App\Models\AdClick::create(['ip' => '31.42.4.14', 'ad_index' => 4, 'created_at' => '2019-06-10 18:10:01', 'ip2long' => ip2long('31.42.4.14')]);
統計訪問數據
App\Models\AdClick::where('ip', '31.42.4.14')->count()
關于MongoDB怎么在Laravel中使用就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。