经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » PHP » 查看文章
在Laravel中使用MongoDB的方法示例
来源:jb51  时间:2019/11/12 8:29:34  对本文有异议

MongoDB实用场景

  • 产品用户访问日志,点击埋点统计信息
  • 业务系统环境参数配置信息
  • 业务系统运行时日志,如laravel.log,nginx.log

使用Homebrew在macoOS安装MongoDB PHP Driver

在macOS中,MongoDB 扩展已经从Homebrew仓库中移除,需要通过pecl安装此扩展。

  1. $ sudo pecl install mongodb -v
  2. ...
  3.  
  4. Build process completed successfully
  5. Installing '/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so'
  6. install ok: channel://pecl.php.net/mongodb-1.5.4
  7. Extension mongodb enabled in php.ini
  8.  

在项目中,使用phpinfo() 查询PHP扩展安装位置。

  1. ...
  2. Configuration File (php.ini) Path /usr/local/etc/php/7.2
  3. Loaded Configuration File /usr/local/etc/php/7.2/php.ini
  4. Scan this dir for additional .ini files /usr/local/etc/php/7.2/conf.d
  5. 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
  6. ....

按照ext-opcache.ini配置,创建一个ext-mongodb.ini文件

  1. touch /usr/local/etc/php/7.2/conf.d/ext-mongodb.ini

将mongodb.so扩展写入该文件

  1. [mongodb]
  2. extension=/usr/local/Cellar/php@7.2/7.2.19/pecl/20170718/mongodb.so

同时在php.ini中移除mongodb.so扩展

  1. extension="mongodb.so" // remove
  2. extension="php_mongodb.so" // remove

重启一下PHP

  1. sudo brew service restart --all

查看是否安装成功

  1. php -m|grep mongodb

在Laravel中使用MongoDB

使用Composer创建一个Laravel项目

  1. composer create-project --prefer-dist laravel/laravel laravel-mongodb-exploer -vvv

成功后,再安装Laravel-MongoDB扩展

  1. composer require jenssegers/mongodb -vvv

按照扩展文档说明,我们添加一个MongoDB数据库连接

  1. //database.php
  2. ...
  3. 'mongodb' => [
  4. 'driver' => 'mongodb',
  5. 'host' => env('MONGODB_HOST', 'localhost'),
  6. 'port' => env('MONGODB_PORT', 27017),
  7. 'database' => env('MONGODB_DATABASE'),
  8. 'username' => env('MONGODB_USERNAME'),
  9. 'password' => env('MONGODB_PASSWORD'),
  10. 'options' => [
  11. 'database' => 'admin' // sets the authentication database required by mongo 3
  12. ]
  13. ],
  14. ...
  15. //.env
  16. ...
  17. MONGODB_HOST=127.0.0.1
  18. MONGODB_PORT=27017
  19. MONGODB_DATABASE=viewers
  20. ...

命令行创建MongoDB数据库

macOS中,在命令行执行mongo开启MongoDB Shell

  1. ./mongo

使用show dbs查看已有数据库

  1. show dbs;
  2.  
  3. admin 0.000GB
  4. config 0.000GB
  5. local 0.000GB
  6. viewers 0.000GB
  7.  

如果没有发现viewers,则创建该数据库。注意只有viewers中存在collection时, 上面结果才会显示viewers

  1. use viewers;

使用数据库后,需要创建colleciton

  1. db.ad_clicks.insert({"ip":"201.35.63.14", "ad_index": 3, "created_at": "2019-06-10 11:34:12"})

使用find查询记录

  1. > db.ad_clicks.find()
  2. { "_id" : ObjectId("5cf71b34e14620598643d23b"), "ip" : "201.34.46.3", "ad_index" : "2", "created_at" : "2019-06-05 11:34:53" }
  3. { "_id" : ObjectId("5cf71d3de14620598643d23d"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" }
  4. { "_id" : ObjectId("5cf71d3ee14620598643d23e"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" }
  5. { "_id" : ObjectId("5cf71d44e14620598643d23f"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 11:11:45" }
  6. { "_id" : ObjectId("5cf71d45e14620598643d240"), "ip" : "200.14.145.64", "ad_index" : 1, "created_at" : "2019-06-04 12:34:12" }
  7. { "_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集合所有记录

  1. DB::connection('mongodb')->table('ad_clicks')->get()

查询单个记录

  1. DB::connection('mongodb')->collection('ad_clicks')->find('5cf71b34e14620598643d23b')

修改某个记录

  1. DB::connection('mongodb')->collection('ad_clicks')->where('_id', '5cf71b34e14620598643d23b')->update(['ad_index'=>2]);

在Laravel ORM中查询MongoDB

在项目中,创建一个Model

  1. php artisan make:model Models/AdClick

修改继承父类和数据库连接,AdClick.php

  1. ...
  2. use Jenssegers\Mongodb\Eloquent\Model;
  3.  
  4. class AdClick extends Model
  5. {
  6. protected $connection = 'mongodb';
  7. /**
  8. * The attributes that are mass assignable.
  9. *
  10. * @var array
  11. */
  12. protected $fillable = [];
  13.  
  14. /**
  15. * The attributes that aren't mass assignable.
  16. *
  17. * @var array
  18. */
  19. protected $guarded = [];
  20. }
  21.  

继续在Thinker中,插入数据

  1. 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')]);

统计访问数据

  1. App\Models\AdClick::where('ip', '31.42.4.14')->count()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号